@jingyi0605/codingns 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +44 -0
- package/bin/codingns.mjs +918 -55
- package/dist/public/assets/{TerminalPage-BlbQuWi1.js → TerminalPage-Dfw1QUqW.js} +19 -19
- package/dist/public/assets/index-DR2rPNi7.css +1 -0
- package/dist/public/assets/index-DTOruahn.js +114 -0
- package/dist/public/index.html +2 -2
- package/dist/server/config/env.d.ts +3 -0
- package/dist/server/config/env.js +35 -3
- package/dist/server/config/env.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +89 -0
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js +138 -0
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -0
- package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +115 -0
- package/dist/server/modules/assistant-capability/assistant-capability-service.js +241 -0
- package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -0
- package/dist/server/modules/butler/butler-control-session-service.d.ts +3 -1
- package/dist/server/modules/butler/butler-control-session-service.js +96 -33
- package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-follow-up-scheduler.d.ts +9 -0
- package/dist/server/modules/butler/butler-follow-up-scheduler.js +47 -11
- package/dist/server/modules/butler/butler-follow-up-scheduler.js.map +1 -1
- package/dist/server/modules/butler/butler-follow-up-service.d.ts +7 -1
- package/dist/server/modules/butler/butler-follow-up-service.js +10 -0
- package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
- package/dist/server/modules/butler/butler-session-service.d.ts +3 -1
- package/dist/server/modules/butler/butler-session-service.js +82 -16
- package/dist/server/modules/butler/butler-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-session-summary-service.d.ts +8 -1
- package/dist/server/modules/butler/butler-session-summary-service.js +34 -7
- package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
- package/dist/server/modules/butler/context-aggregator.js +44 -13
- package/dist/server/modules/butler/context-aggregator.js.map +1 -1
- package/dist/server/modules/butler/patrol-scheduler.d.ts +9 -0
- package/dist/server/modules/butler/patrol-scheduler.js +63 -9
- package/dist/server/modules/butler/patrol-scheduler.js.map +1 -1
- package/dist/server/modules/butler/session-summary-scheduler.d.ts +9 -0
- package/dist/server/modules/butler/session-summary-scheduler.js +47 -11
- package/dist/server/modules/butler/session-summary-scheduler.js.map +1 -1
- package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.d.ts +38 -0
- package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.js +99 -0
- package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.js.map +1 -0
- package/dist/server/modules/debug-target/debug-target-controller.d.ts +70 -0
- package/dist/server/modules/debug-target/debug-target-controller.js +113 -0
- package/dist/server/modules/debug-target/debug-target-controller.js.map +1 -0
- package/dist/server/modules/debug-target/debug-target-service.d.ts +105 -0
- package/dist/server/modules/debug-target/debug-target-service.js +1644 -0
- package/dist/server/modules/debug-target/debug-target-service.js.map +1 -0
- package/dist/server/modules/debug-target/framework-compatibility-matrix.d.ts +4 -0
- package/dist/server/modules/debug-target/framework-compatibility-matrix.js +45 -0
- package/dist/server/modules/debug-target/framework-compatibility-matrix.js.map +1 -0
- package/dist/server/modules/debug-target/launch-adapter-registry.d.ts +25 -0
- package/dist/server/modules/debug-target/launch-adapter-registry.js +445 -0
- package/dist/server/modules/debug-target/launch-adapter-registry.js.map +1 -0
- package/dist/server/modules/file/file-constants.d.ts +1 -0
- package/dist/server/modules/file/file-constants.js +1 -0
- package/dist/server/modules/file/file-constants.js.map +1 -1
- package/dist/server/modules/file/file-content-service.d.ts +2 -1
- package/dist/server/modules/file/file-content-service.js +53 -0
- package/dist/server/modules/file/file-content-service.js.map +1 -1
- package/dist/server/modules/file/file-controller.js +12 -3
- package/dist/server/modules/file/file-controller.js.map +1 -1
- package/dist/server/modules/file/file-preview-link-service.js +6 -37
- package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
- package/dist/server/modules/file/file-preview-service.d.ts +6 -12
- package/dist/server/modules/file/file-preview-service.js +114 -28
- package/dist/server/modules/file/file-preview-service.js.map +1 -1
- package/dist/server/modules/file/file-preview-types.d.ts +37 -0
- package/dist/server/modules/file/file-preview-types.js +84 -0
- package/dist/server/modules/file/file-preview-types.js.map +1 -0
- package/dist/server/modules/git/commit-orchestrator.d.ts +4 -1
- package/dist/server/modules/git/commit-orchestrator.js +18 -1
- package/dist/server/modules/git/commit-orchestrator.js.map +1 -1
- package/dist/server/modules/git/git-auth.d.ts +25 -0
- package/dist/server/modules/git/git-auth.js +88 -0
- package/dist/server/modules/git/git-auth.js.map +1 -0
- package/dist/server/modules/git/git-controller.d.ts +12 -0
- package/dist/server/modules/git/git-controller.js +18 -1
- package/dist/server/modules/git/git-controller.js.map +1 -1
- package/dist/server/modules/git/git-read-service.d.ts +3 -1
- package/dist/server/modules/git/git-read-service.js +119 -2
- package/dist/server/modules/git/git-read-service.js.map +1 -1
- package/dist/server/modules/git/git-remote-credential-service.d.ts +9 -0
- package/dist/server/modules/git/git-remote-credential-service.js +76 -0
- package/dist/server/modules/git/git-remote-credential-service.js.map +1 -0
- package/dist/server/modules/git/git-write-service.d.ts +5 -2
- package/dist/server/modules/git/git-write-service.js +33 -17
- package/dist/server/modules/git/git-write-service.js.map +1 -1
- package/dist/server/modules/git/types.d.ts +26 -0
- package/dist/server/modules/git/workspace-repo-guard.js +3 -2
- package/dist/server/modules/git/workspace-repo-guard.js.map +1 -1
- package/dist/server/modules/provider/codex-model-options.d.ts +3 -1
- package/dist/server/modules/provider/codex-model-options.js +4 -1
- package/dist/server/modules/provider/codex-model-options.js.map +1 -1
- package/dist/server/modules/provider/opencode-model-options.d.ts +3 -1
- package/dist/server/modules/provider/opencode-model-options.js +5 -1
- package/dist/server/modules/provider/opencode-model-options.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-helper-client.d.ts +24 -0
- package/dist/server/modules/provider/provider-discovery-helper-client.js +14 -0
- package/dist/server/modules/provider/provider-discovery-helper-client.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-helper-process.js +54 -0
- package/dist/server/modules/provider/provider-discovery-helper-process.js.map +1 -1
- package/dist/server/modules/sessions/session-activity-authority-service.js +13 -1
- package/dist/server/modules/sessions/session-activity-authority-service.js.map +1 -1
- package/dist/server/modules/sessions/session-activity-inspector.js +21 -5
- package/dist/server/modules/sessions/session-activity-inspector.js.map +1 -1
- package/dist/server/modules/sessions/session-controller.d.ts +5 -0
- package/dist/server/modules/sessions/session-controller.js +16 -0
- package/dist/server/modules/sessions/session-controller.js.map +1 -1
- package/dist/server/modules/sessions/session-history-service.d.ts +27 -7
- package/dist/server/modules/sessions/session-history-service.js +439 -81
- package/dist/server/modules/sessions/session-history-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-service.d.ts +2 -1
- package/dist/server/modules/sessions/session-live-runtime-service.js +12 -0
- package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
- package/dist/server/modules/skills/skill-controller.d.ts +23 -0
- package/dist/server/modules/skills/skill-controller.js +35 -0
- package/dist/server/modules/skills/skill-controller.js.map +1 -0
- package/dist/server/modules/skills/skill-manager-service.d.ts +86 -0
- package/dist/server/modules/skills/skill-manager-service.js +557 -0
- package/dist/server/modules/skills/skill-manager-service.js.map +1 -0
- package/dist/server/modules/skills/skill-reconciler.d.ts +21 -0
- package/dist/server/modules/skills/skill-reconciler.js +99 -0
- package/dist/server/modules/skills/skill-reconciler.js.map +1 -0
- package/dist/server/modules/skills/skill-sync-planner.d.ts +8 -0
- package/dist/server/modules/skills/skill-sync-planner.js +20 -0
- package/dist/server/modules/skills/skill-sync-planner.js.map +1 -0
- package/dist/server/modules/skills/skill-target-adapter.d.ts +34 -0
- package/dist/server/modules/skills/skill-target-adapter.js +65 -0
- package/dist/server/modules/skills/skill-target-adapter.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-controller.d.ts +15 -0
- package/dist/server/modules/tailscale/tailscale-controller.js +33 -0
- package/dist/server/modules/tailscale/tailscale-controller.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-helper-client.d.ts +41 -0
- package/dist/server/modules/tailscale/tailscale-helper-client.js +135 -0
- package/dist/server/modules/tailscale/tailscale-helper-client.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-helper-process.d.ts +1 -0
- package/dist/server/modules/tailscale/tailscale-helper-process.js +327 -0
- package/dist/server/modules/tailscale/tailscale-helper-process.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-manager.d.ts +41 -0
- package/dist/server/modules/tailscale/tailscale-manager.js +259 -0
- package/dist/server/modules/tailscale/tailscale-manager.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-service.d.ts +43 -0
- package/dist/server/modules/tailscale/tailscale-service.js +201 -0
- package/dist/server/modules/tailscale/tailscale-service.js.map +1 -0
- package/dist/server/modules/tasks/event-loop-monitor.d.ts +21 -0
- package/dist/server/modules/tasks/event-loop-monitor.js +64 -0
- package/dist/server/modules/tasks/event-loop-monitor.js.map +1 -0
- package/dist/server/modules/tasks/observability-controller.d.ts +30 -0
- package/dist/server/modules/tasks/observability-controller.js +44 -0
- package/dist/server/modules/tasks/observability-controller.js.map +1 -0
- package/dist/server/modules/tasks/observability-service.d.ts +32 -0
- package/dist/server/modules/tasks/observability-service.js +104 -0
- package/dist/server/modules/tasks/observability-service.js.map +1 -0
- package/dist/server/modules/tasks/scheduler-metrics.d.ts +41 -0
- package/dist/server/modules/tasks/scheduler-metrics.js +92 -0
- package/dist/server/modules/tasks/scheduler-metrics.js.map +1 -0
- package/dist/server/modules/tasks/task-activity-log.d.ts +39 -0
- package/dist/server/modules/tasks/task-activity-log.js +43 -0
- package/dist/server/modules/tasks/task-activity-log.js.map +1 -0
- package/dist/server/modules/tasks/task-helper-client.d.ts +11 -0
- package/dist/server/modules/tasks/task-helper-client.js +132 -0
- package/dist/server/modules/tasks/task-helper-client.js.map +1 -0
- package/dist/server/modules/tasks/task-helper-process-handlers.d.ts +16 -0
- package/dist/server/modules/tasks/task-helper-process-handlers.js +14 -0
- package/dist/server/modules/tasks/task-helper-process-handlers.js.map +1 -0
- package/dist/server/modules/tasks/task-helper-process.d.ts +1 -0
- package/dist/server/modules/tasks/task-helper-process.js +49 -0
- package/dist/server/modules/tasks/task-helper-process.js.map +1 -0
- package/dist/server/modules/tasks/task-lane-executors.d.ts +2 -0
- package/dist/server/modules/tasks/task-lane-executors.js +15 -0
- package/dist/server/modules/tasks/task-lane-executors.js.map +1 -0
- package/dist/server/modules/tasks/task-manager.d.ts +15 -0
- package/dist/server/modules/tasks/task-manager.js +36 -0
- package/dist/server/modules/tasks/task-manager.js.map +1 -0
- package/dist/server/modules/tasks/task-metrics.d.ts +9 -0
- package/dist/server/modules/tasks/task-metrics.js +81 -0
- package/dist/server/modules/tasks/task-metrics.js.map +1 -0
- package/dist/server/modules/tasks/task-registry.d.ts +7 -0
- package/dist/server/modules/tasks/task-registry.js +21 -0
- package/dist/server/modules/tasks/task-registry.js.map +1 -0
- package/dist/server/modules/tasks/task-scheduler.d.ts +31 -0
- package/dist/server/modules/tasks/task-scheduler.js +473 -0
- package/dist/server/modules/tasks/task-scheduler.js.map +1 -0
- package/dist/server/modules/tasks/task-types.d.ts +106 -0
- package/dist/server/modules/tasks/task-types.js +23 -0
- package/dist/server/modules/tasks/task-types.js.map +1 -0
- package/dist/server/modules/terminal/command-template-service.d.ts +4 -0
- package/dist/server/modules/terminal/command-template-service.js +5 -3
- package/dist/server/modules/terminal/command-template-service.js.map +1 -1
- package/dist/server/modules/terminal/runtime/terminal-log-spooler.d.ts +7 -3
- package/dist/server/modules/terminal/runtime/terminal-log-spooler.js +95 -15
- package/dist/server/modules/terminal/runtime/terminal-log-spooler.js.map +1 -1
- package/dist/server/modules/terminal/runtime/terminal-log-writer-client.d.ts +21 -0
- package/dist/server/modules/terminal/runtime/terminal-log-writer-client.js +144 -0
- package/dist/server/modules/terminal/runtime/terminal-log-writer-client.js.map +1 -0
- package/dist/server/modules/terminal/runtime/terminal-log-writer-process.d.ts +1 -0
- package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js +187 -0
- package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js.map +1 -0
- package/dist/server/modules/terminal/terminal-service.d.ts +12 -0
- package/dist/server/modules/terminal/terminal-service.js +34 -17
- package/dist/server/modules/terminal/terminal-service.js.map +1 -1
- package/dist/server/modules/workbench/workbench-service.d.ts +23 -2
- package/dist/server/modules/workbench/workbench-service.js +126 -15
- package/dist/server/modules/workbench/workbench-service.js.map +1 -1
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +5 -1
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +88 -19
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -1
- package/dist/server/modules/workspace/workspace-code-composition.d.ts +2 -0
- package/dist/server/modules/workspace/workspace-code-composition.js +154 -0
- package/dist/server/modules/workspace/workspace-code-composition.js.map +1 -0
- package/dist/server/modules/workspace/workspace-controller.d.ts +14 -0
- package/dist/server/modules/workspace/workspace-controller.js +19 -0
- package/dist/server/modules/workspace/workspace-controller.js.map +1 -1
- package/dist/server/modules/workspace/workspace-service.d.ts +21 -14
- package/dist/server/modules/workspace/workspace-service.js +183 -234
- package/dist/server/modules/workspace/workspace-service.js.map +1 -1
- package/dist/server/modules/worktree/worktree-cleanup-service.d.ts +35 -0
- package/dist/server/modules/worktree/worktree-cleanup-service.js +210 -0
- package/dist/server/modules/worktree/worktree-cleanup-service.js.map +1 -0
- package/dist/server/modules/worktree/worktree-controller.d.ts +44 -0
- package/dist/server/modules/worktree/worktree-controller.js +40 -0
- package/dist/server/modules/worktree/worktree-controller.js.map +1 -0
- package/dist/server/modules/worktree/worktree-manager.d.ts +34 -0
- package/dist/server/modules/worktree/worktree-manager.js +292 -0
- package/dist/server/modules/worktree/worktree-manager.js.map +1 -0
- package/dist/server/modules/worktree/worktree-merge-service.d.ts +52 -0
- package/dist/server/modules/worktree/worktree-merge-service.js +293 -0
- package/dist/server/modules/worktree/worktree-merge-service.js.map +1 -0
- package/dist/server/modules/worktree/worktree-sync-service.d.ts +23 -0
- package/dist/server/modules/worktree/worktree-sync-service.js +166 -0
- package/dist/server/modules/worktree/worktree-sync-service.js.map +1 -0
- package/dist/server/routes/assistant.d.ts +3 -0
- package/dist/server/routes/assistant.js +15 -0
- package/dist/server/routes/assistant.js.map +1 -0
- package/dist/server/routes/debug-targets.d.ts +3 -0
- package/dist/server/routes/debug-targets.js +15 -0
- package/dist/server/routes/debug-targets.js.map +1 -0
- package/dist/server/routes/git.js +2 -0
- package/dist/server/routes/git.js.map +1 -1
- package/dist/server/routes/observability.d.ts +3 -0
- package/dist/server/routes/observability.js +7 -0
- package/dist/server/routes/observability.js.map +1 -0
- package/dist/server/routes/skills.d.ts +3 -0
- package/dist/server/routes/skills.js +7 -0
- package/dist/server/routes/skills.js.map +1 -0
- package/dist/server/routes/system.d.ts +3 -0
- package/dist/server/routes/system.js +9 -0
- package/dist/server/routes/system.js.map +1 -0
- package/dist/server/routes/workspaces.js +2 -0
- package/dist/server/routes/workspaces.js.map +1 -1
- package/dist/server/routes/worktrees.d.ts +3 -0
- package/dist/server/routes/worktrees.js +8 -0
- package/dist/server/routes/worktrees.js.map +1 -0
- package/dist/server/server/create-server.d.ts +46 -0
- package/dist/server/server/create-server.js +141 -12
- package/dist/server/server/create-server.js.map +1 -1
- package/dist/server/shared/utils/command-availability.d.ts +1 -0
- package/dist/server/shared/utils/command-availability.js +26 -3
- package/dist/server/shared/utils/command-availability.js.map +1 -1
- package/dist/server/shared/utils/secret-box.d.ts +2 -0
- package/dist/server/shared/utils/secret-box.js +29 -0
- package/dist/server/shared/utils/secret-box.js.map +1 -0
- package/dist/server/shared/utils/terminal-debug-log.js +5 -3
- package/dist/server/shared/utils/terminal-debug-log.js.map +1 -1
- package/dist/server/storage/repositories/ai-fallback-edit-repository.d.ts +11 -0
- package/dist/server/storage/repositories/ai-fallback-edit-repository.js +118 -0
- package/dist/server/storage/repositories/ai-fallback-edit-repository.js.map +1 -0
- package/dist/server/storage/repositories/debug-runtime-session-repository.d.ts +11 -0
- package/dist/server/storage/repositories/debug-runtime-session-repository.js +100 -0
- package/dist/server/storage/repositories/debug-runtime-session-repository.js.map +1 -0
- package/dist/server/storage/repositories/debug-service-repository.d.ts +9 -0
- package/dist/server/storage/repositories/debug-service-repository.js +99 -0
- package/dist/server/storage/repositories/debug-service-repository.js.map +1 -0
- package/dist/server/storage/repositories/debug-target-repository.d.ts +11 -0
- package/dist/server/storage/repositories/debug-target-repository.js +100 -0
- package/dist/server/storage/repositories/debug-target-repository.js.map +1 -0
- package/dist/server/storage/repositories/framework-analysis-result-repository.d.ts +9 -0
- package/dist/server/storage/repositories/framework-analysis-result-repository.js +98 -0
- package/dist/server/storage/repositories/framework-analysis-result-repository.js.map +1 -0
- package/dist/server/storage/repositories/git-remote-credential-repository.d.ts +9 -0
- package/dist/server/storage/repositories/git-remote-credential-repository.js +51 -0
- package/dist/server/storage/repositories/git-remote-credential-repository.js.map +1 -0
- package/dist/server/storage/repositories/instance-tailscale-repository.d.ts +10 -0
- package/dist/server/storage/repositories/instance-tailscale-repository.js +112 -0
- package/dist/server/storage/repositories/instance-tailscale-repository.js.map +1 -0
- package/dist/server/storage/repositories/managed-skill-repository.d.ts +11 -0
- package/dist/server/storage/repositories/managed-skill-repository.js +102 -0
- package/dist/server/storage/repositories/managed-skill-repository.js.map +1 -0
- package/dist/server/storage/repositories/port-lease-repository.d.ts +12 -0
- package/dist/server/storage/repositories/port-lease-repository.js +124 -0
- package/dist/server/storage/repositories/port-lease-repository.js.map +1 -0
- package/dist/server/storage/repositories/runtime-binding-repository.d.ts +10 -0
- package/dist/server/storage/repositories/runtime-binding-repository.js +89 -0
- package/dist/server/storage/repositories/runtime-binding-repository.js.map +1 -0
- package/dist/server/storage/repositories/skill-target-binding-repository.d.ts +10 -0
- package/dist/server/storage/repositories/skill-target-binding-repository.js +77 -0
- package/dist/server/storage/repositories/skill-target-binding-repository.js.map +1 -0
- package/dist/server/storage/repositories/terminal-command-template-repository.js +77 -4
- package/dist/server/storage/repositories/terminal-command-template-repository.js.map +1 -1
- package/dist/server/storage/repositories/terminal-instance-repository.js +89 -7
- package/dist/server/storage/repositories/terminal-instance-repository.js.map +1 -1
- package/dist/server/storage/repositories/workspace-navigation-state-repository.d.ts +9 -0
- package/dist/server/storage/repositories/workspace-navigation-state-repository.js +49 -0
- package/dist/server/storage/repositories/workspace-navigation-state-repository.js.map +1 -0
- package/dist/server/storage/repositories/workspace-repository.d.ts +7 -1
- package/dist/server/storage/repositories/workspace-repository.js +32 -8
- package/dist/server/storage/repositories/workspace-repository.js.map +1 -1
- package/dist/server/storage/repositories/workspace-worktree-repository.d.ts +13 -0
- package/dist/server/storage/repositories/workspace-worktree-repository.js +158 -0
- package/dist/server/storage/repositories/workspace-worktree-repository.js.map +1 -0
- package/dist/server/storage/sqlite/client.js +311 -0
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +303 -0
- package/dist/server/types/domain.d.ts +303 -0
- package/dist/server/ws/workbench-ws-hub.js +33 -9
- package/dist/server/ws/workbench-ws-hub.js.map +1 -1
- package/dist/server/ws/ws-server.js +4 -4
- package/dist/server/ws/ws-server.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +18 -6
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +14 -2
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +25 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/types.d.ts +6 -0
- package/package.json +1 -1
- package/dist/public/assets/index-1VIm8lVL.css +0 -1
- package/dist/public/assets/index-Dti93O2S.js +0 -109
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
export class SchedulerMetrics {
|
|
2
|
+
schedulers = new Map();
|
|
3
|
+
recordTick(observation) {
|
|
4
|
+
const state = this.getState(observation.schedulerName);
|
|
5
|
+
const durationMs = Math.max(0, observation.durationMs);
|
|
6
|
+
const errorCount = Math.max(0, observation.errorCount ?? 0);
|
|
7
|
+
state.tickTotal += 1;
|
|
8
|
+
state.taskCountTotal += Math.max(0, observation.taskCount);
|
|
9
|
+
state.errorTotal += errorCount;
|
|
10
|
+
state.lastTickAt = observation.referenceAt;
|
|
11
|
+
state.lastDurationMs = durationMs;
|
|
12
|
+
state.lastTaskCount = Math.max(0, observation.taskCount);
|
|
13
|
+
state.lastIdle = observation.idle;
|
|
14
|
+
state.lastErrorCount = errorCount;
|
|
15
|
+
state.nextDelayMs = observation.nextDelayMs ?? null;
|
|
16
|
+
state.idleStreak = Math.max(0, observation.idleStreak ?? 0);
|
|
17
|
+
if (observation.idle) {
|
|
18
|
+
state.idleTickTotal += 1;
|
|
19
|
+
}
|
|
20
|
+
state.durationMs.count += 1;
|
|
21
|
+
state.durationMs.total += durationMs;
|
|
22
|
+
state.durationMs.max = Math.max(state.durationMs.max, durationMs);
|
|
23
|
+
state.durationMs.min =
|
|
24
|
+
state.durationMs.min === null ? durationMs : Math.min(state.durationMs.min, durationMs);
|
|
25
|
+
}
|
|
26
|
+
observe() {
|
|
27
|
+
return {
|
|
28
|
+
schedulers: Object.fromEntries([...this.schedulers.entries()].map(([name, state]) => [
|
|
29
|
+
name,
|
|
30
|
+
{
|
|
31
|
+
tickTotal: state.tickTotal,
|
|
32
|
+
idleTickTotal: state.idleTickTotal,
|
|
33
|
+
errorTotal: state.errorTotal,
|
|
34
|
+
taskCountTotal: state.taskCountTotal,
|
|
35
|
+
durationMs: snapshotDuration(state.durationMs),
|
|
36
|
+
lastTickAt: state.lastTickAt,
|
|
37
|
+
lastDurationMs: state.lastDurationMs,
|
|
38
|
+
lastTaskCount: state.lastTaskCount,
|
|
39
|
+
lastIdle: state.lastIdle,
|
|
40
|
+
lastErrorCount: state.lastErrorCount,
|
|
41
|
+
nextDelayMs: state.nextDelayMs,
|
|
42
|
+
idleStreak: state.idleStreak
|
|
43
|
+
}
|
|
44
|
+
]))
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
getState(name) {
|
|
48
|
+
const existing = this.schedulers.get(name);
|
|
49
|
+
if (existing) {
|
|
50
|
+
return existing;
|
|
51
|
+
}
|
|
52
|
+
const created = {
|
|
53
|
+
tickTotal: 0,
|
|
54
|
+
idleTickTotal: 0,
|
|
55
|
+
errorTotal: 0,
|
|
56
|
+
taskCountTotal: 0,
|
|
57
|
+
durationMs: {
|
|
58
|
+
count: 0,
|
|
59
|
+
total: 0,
|
|
60
|
+
max: 0,
|
|
61
|
+
min: null
|
|
62
|
+
},
|
|
63
|
+
lastTickAt: null,
|
|
64
|
+
lastDurationMs: null,
|
|
65
|
+
lastTaskCount: 0,
|
|
66
|
+
lastIdle: false,
|
|
67
|
+
lastErrorCount: 0,
|
|
68
|
+
nextDelayMs: null,
|
|
69
|
+
idleStreak: 0
|
|
70
|
+
};
|
|
71
|
+
this.schedulers.set(name, created);
|
|
72
|
+
return created;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
export function resolveAdaptiveSchedulerDelayMs(baseIntervalMs, maxIntervalMs, idleStreak) {
|
|
76
|
+
const normalizedBase = Math.max(1, Math.floor(baseIntervalMs));
|
|
77
|
+
const normalizedMax = Math.max(normalizedBase, Math.floor(maxIntervalMs));
|
|
78
|
+
if (idleStreak <= 0) {
|
|
79
|
+
return normalizedBase;
|
|
80
|
+
}
|
|
81
|
+
return Math.min(normalizedMax, normalizedBase * (2 ** Math.max(0, idleStreak - 1)));
|
|
82
|
+
}
|
|
83
|
+
function snapshotDuration(state) {
|
|
84
|
+
return {
|
|
85
|
+
count: state.count,
|
|
86
|
+
total: state.total,
|
|
87
|
+
max: state.max,
|
|
88
|
+
min: state.min,
|
|
89
|
+
avg: state.count > 0 ? state.total / state.count : 0
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=scheduler-metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scheduler-metrics.js","sourceRoot":"","sources":["../../../../src/modules/tasks/scheduler-metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { TaskExecutionLane, TaskStatus } from "./task-types.js";
|
|
2
|
+
export type TaskActivityEventType = "enqueued" | "deduped" | "started" | "finished" | "failed" | "cancelled" | "timeout" | "cache_hit";
|
|
3
|
+
export interface TaskActivityRecord {
|
|
4
|
+
readonly eventId: string;
|
|
5
|
+
readonly recordedAt: string;
|
|
6
|
+
readonly eventType: TaskActivityEventType;
|
|
7
|
+
readonly taskId: string | null;
|
|
8
|
+
readonly taskType: string;
|
|
9
|
+
readonly key: string;
|
|
10
|
+
readonly executionLane: TaskExecutionLane;
|
|
11
|
+
readonly source: string | null;
|
|
12
|
+
readonly status: TaskStatus | null;
|
|
13
|
+
readonly attempt: number | null;
|
|
14
|
+
readonly waitMs: number | null;
|
|
15
|
+
readonly runMs: number | null;
|
|
16
|
+
readonly errorMessage: string | null;
|
|
17
|
+
}
|
|
18
|
+
export interface TaskActivityEventInput {
|
|
19
|
+
readonly eventType: TaskActivityEventType;
|
|
20
|
+
readonly taskId?: string | null;
|
|
21
|
+
readonly taskType: string;
|
|
22
|
+
readonly key: string;
|
|
23
|
+
readonly executionLane: TaskExecutionLane;
|
|
24
|
+
readonly source?: string | null;
|
|
25
|
+
readonly status?: TaskStatus | null;
|
|
26
|
+
readonly attempt?: number | null;
|
|
27
|
+
readonly waitMs?: number | null;
|
|
28
|
+
readonly runMs?: number | null;
|
|
29
|
+
readonly errorMessage?: string | null;
|
|
30
|
+
}
|
|
31
|
+
export declare class TaskActivityLog {
|
|
32
|
+
private readonly isEnabled;
|
|
33
|
+
private readonly limit;
|
|
34
|
+
private readonly records;
|
|
35
|
+
constructor(isEnabled: () => boolean, limit?: number);
|
|
36
|
+
record(input: TaskActivityEventInput): void;
|
|
37
|
+
list(limit?: number): TaskActivityRecord[];
|
|
38
|
+
clear(): void;
|
|
39
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { createId } from "../../shared/utils/id.js";
|
|
2
|
+
import { nowIso } from "../../shared/utils/time.js";
|
|
3
|
+
export class TaskActivityLog {
|
|
4
|
+
isEnabled;
|
|
5
|
+
limit;
|
|
6
|
+
records = [];
|
|
7
|
+
constructor(isEnabled, limit = 200) {
|
|
8
|
+
this.isEnabled = isEnabled;
|
|
9
|
+
this.limit = limit;
|
|
10
|
+
}
|
|
11
|
+
record(input) {
|
|
12
|
+
if (!this.isEnabled()) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
this.records.unshift({
|
|
16
|
+
eventId: createId(),
|
|
17
|
+
recordedAt: nowIso(),
|
|
18
|
+
eventType: input.eventType,
|
|
19
|
+
taskId: input.taskId ?? null,
|
|
20
|
+
taskType: input.taskType,
|
|
21
|
+
key: input.key,
|
|
22
|
+
executionLane: input.executionLane,
|
|
23
|
+
source: input.source ?? null,
|
|
24
|
+
status: input.status ?? null,
|
|
25
|
+
attempt: input.attempt ?? null,
|
|
26
|
+
waitMs: input.waitMs ?? null,
|
|
27
|
+
runMs: input.runMs ?? null,
|
|
28
|
+
errorMessage: input.errorMessage ?? null
|
|
29
|
+
});
|
|
30
|
+
if (this.records.length > this.limit) {
|
|
31
|
+
this.records.length = this.limit;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
list(limit = 100) {
|
|
35
|
+
return this.records.slice(0, Math.max(1, limit)).map((record) => ({
|
|
36
|
+
...record
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
clear() {
|
|
40
|
+
this.records.length = 0;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=task-activity-log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-activity-log.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-activity-log.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAC;AA2CpD,MAAM,OAAO,eAAe;IAIP;IACA;IAJF,OAAO,GAAyB,EAAE,CAAC;IAEpD,YACmB,SAAwB,EACxB,QAAQ,GAAG;QADX,cAAS,GAAT,SAAS,CAAe;QACxB,UAAK,GAAL,KAAK,CAAM;IAC3B,CAAC;IAEJ,MAAM,CAAC,KAA6B;QAClC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;YACnB,OAAO,EAAE,QAAQ,EAAE;YACnB,UAAU,EAAE,MAAM,EAAE;YACpB,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI;YAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI;YAC5B,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI;YAC5B,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,IAAI;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI;YAC5B,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,IAAI;YAC1B,YAAY,EAAE,KAAK,CAAC,YAAY,IAAI,IAAI;SACzC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YACrC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC;QACnC,CAAC;IACH,CAAC;IAED,IAAI,CAAC,KAAK,GAAG,GAAG;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAChE,GAAG,MAAM;SACV,CAAC,CAAC,CAAC;IACN,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;IAC1B,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { TaskHelperProcessHandlerName } from "./task-helper-process-handlers.js";
|
|
2
|
+
export declare class TaskHelperProcessClient {
|
|
3
|
+
private readonly child;
|
|
4
|
+
private readonly stdoutReader;
|
|
5
|
+
private readonly pendingRequests;
|
|
6
|
+
private nextRequestId;
|
|
7
|
+
constructor();
|
|
8
|
+
execute<TResult>(handler: TaskHelperProcessHandlerName, input: unknown, signal?: AbortSignal): Promise<TResult>;
|
|
9
|
+
private handleResponseLine;
|
|
10
|
+
private rejectAll;
|
|
11
|
+
}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { spawn } from "node:child_process";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import readline from "node:readline";
|
|
4
|
+
import { fileURLToPath } from "node:url";
|
|
5
|
+
export class TaskHelperProcessClient {
|
|
6
|
+
child;
|
|
7
|
+
stdoutReader;
|
|
8
|
+
pendingRequests = new Map();
|
|
9
|
+
nextRequestId = 1;
|
|
10
|
+
constructor() {
|
|
11
|
+
const launch = resolveHelperLaunch();
|
|
12
|
+
this.child = spawn(launch.command, launch.args, {
|
|
13
|
+
cwd: process.cwd(),
|
|
14
|
+
env: process.env,
|
|
15
|
+
stdio: ["pipe", "pipe", "pipe"]
|
|
16
|
+
});
|
|
17
|
+
this.stdoutReader = readline.createInterface({
|
|
18
|
+
input: this.child.stdout
|
|
19
|
+
});
|
|
20
|
+
this.stdoutReader.on("line", (line) => {
|
|
21
|
+
this.handleResponseLine(line);
|
|
22
|
+
});
|
|
23
|
+
this.child.stderr.on("data", (chunk) => {
|
|
24
|
+
const content = String(chunk).trim();
|
|
25
|
+
if (content) {
|
|
26
|
+
console.warn(`[task-helper] ${content}`);
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
this.child.on("error", (error) => {
|
|
30
|
+
this.rejectAll(error);
|
|
31
|
+
});
|
|
32
|
+
this.child.on("exit", (code, signal) => {
|
|
33
|
+
this.rejectAll(new Error(`task helper 已退出:code=${code ?? "null"} signal=${signal ?? "null"}`));
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
async execute(handler, input, signal) {
|
|
37
|
+
const id = String(this.nextRequestId++);
|
|
38
|
+
return await new Promise((resolve, reject) => {
|
|
39
|
+
let aborted = false;
|
|
40
|
+
let onAbort = null;
|
|
41
|
+
if (signal) {
|
|
42
|
+
onAbort = () => {
|
|
43
|
+
aborted = true;
|
|
44
|
+
this.pendingRequests.delete(id);
|
|
45
|
+
reject(signal.reason ?? new Error("helper task aborted"));
|
|
46
|
+
};
|
|
47
|
+
if (signal.aborted) {
|
|
48
|
+
onAbort();
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
signal.addEventListener("abort", onAbort, { once: true });
|
|
52
|
+
}
|
|
53
|
+
this.pendingRequests.set(id, {
|
|
54
|
+
resolve: (value) => {
|
|
55
|
+
if (onAbort && signal) {
|
|
56
|
+
signal.removeEventListener("abort", onAbort);
|
|
57
|
+
}
|
|
58
|
+
if (!aborted) {
|
|
59
|
+
resolve(value);
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
reject: (error) => {
|
|
63
|
+
if (onAbort && signal) {
|
|
64
|
+
signal.removeEventListener("abort", onAbort);
|
|
65
|
+
}
|
|
66
|
+
if (!aborted) {
|
|
67
|
+
reject(error);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
this.child.stdin.write(`${JSON.stringify({
|
|
72
|
+
id,
|
|
73
|
+
handler,
|
|
74
|
+
input
|
|
75
|
+
})}\n`, (error) => {
|
|
76
|
+
if (!error) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
if (onAbort && signal) {
|
|
80
|
+
signal.removeEventListener("abort", onAbort);
|
|
81
|
+
}
|
|
82
|
+
this.pendingRequests.delete(id);
|
|
83
|
+
reject(error);
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
handleResponseLine(line) {
|
|
88
|
+
const trimmed = line.trim();
|
|
89
|
+
if (!trimmed.startsWith("{")) {
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
let payload;
|
|
93
|
+
try {
|
|
94
|
+
payload = JSON.parse(trimmed);
|
|
95
|
+
}
|
|
96
|
+
catch {
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const pending = this.pendingRequests.get(payload.id);
|
|
100
|
+
if (!pending) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
this.pendingRequests.delete(payload.id);
|
|
104
|
+
if (payload.ok) {
|
|
105
|
+
pending.resolve(payload.result);
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
pending.reject(new Error(payload.error));
|
|
109
|
+
}
|
|
110
|
+
rejectAll(error) {
|
|
111
|
+
for (const pending of this.pendingRequests.values()) {
|
|
112
|
+
pending.reject(error);
|
|
113
|
+
}
|
|
114
|
+
this.pendingRequests.clear();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
function resolveHelperLaunch() {
|
|
118
|
+
const currentFilePath = fileURLToPath(import.meta.url);
|
|
119
|
+
const extension = path.extname(currentFilePath);
|
|
120
|
+
const helperPath = currentFilePath.replace(/task-helper-client\.(ts|js)$/, `task-helper-process${extension}`);
|
|
121
|
+
if (extension === ".ts") {
|
|
122
|
+
return {
|
|
123
|
+
command: process.execPath,
|
|
124
|
+
args: ["--import", "tsx", helperPath]
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
command: process.execPath,
|
|
129
|
+
args: [helperPath]
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
//# sourceMappingURL=task-helper-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-helper-client.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-helper-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { TerminalTemplateRuntimeStatus } from "../../types/domain.js";
|
|
2
|
+
import type { WorkspaceCodeCompositionSummary } from "../workspace/workspace-service.js";
|
|
3
|
+
interface TaskHelperProcessHandlerMap {
|
|
4
|
+
"workspace.code_composition_scan": (input: {
|
|
5
|
+
workspacePath: string;
|
|
6
|
+
}) => WorkspaceCodeCompositionSummary | Promise<WorkspaceCodeCompositionSummary>;
|
|
7
|
+
"terminal.template_runtime_status_discovery": (input: {
|
|
8
|
+
items: Array<{
|
|
9
|
+
templateId: string;
|
|
10
|
+
port: number;
|
|
11
|
+
}>;
|
|
12
|
+
}) => TerminalTemplateRuntimeStatus[] | Promise<TerminalTemplateRuntimeStatus[]>;
|
|
13
|
+
}
|
|
14
|
+
export type TaskHelperProcessHandlerName = keyof TaskHelperProcessHandlerMap;
|
|
15
|
+
export declare function runTaskHelperProcessHandler(handler: TaskHelperProcessHandlerName, input: unknown): Promise<unknown>;
|
|
16
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { discoverTemplateRuntimeStatuses } from "../terminal/template-port-runtime.js";
|
|
2
|
+
import { readWorkspaceCodeComposition } from "../workspace/workspace-code-composition.js";
|
|
3
|
+
const TASK_HELPER_PROCESS_HANDLERS = {
|
|
4
|
+
"workspace.code_composition_scan": ({ workspacePath }) => readWorkspaceCodeComposition(workspacePath),
|
|
5
|
+
"terminal.template_runtime_status_discovery": ({ items }) => discoverTemplateRuntimeStatuses(items)
|
|
6
|
+
};
|
|
7
|
+
export async function runTaskHelperProcessHandler(handler, input) {
|
|
8
|
+
const handlerFn = TASK_HELPER_PROCESS_HANDLERS[handler];
|
|
9
|
+
if (!handlerFn) {
|
|
10
|
+
throw new Error(`未知 helper_process 处理器: ${handler}`);
|
|
11
|
+
}
|
|
12
|
+
return await handlerFn(input);
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=task-helper-process-handlers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-helper-process-handlers.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-helper-process-handlers.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,+BAA+B,EAAE,MAAM,sCAAsC,CAAC;AACvF,OAAO,EACL,4BAA4B,EAC7B,MAAM,4CAA4C,CAAC;AAYpD,MAAM,4BAA4B,GAAgC;IAChE,iCAAiC,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CACvD,4BAA4B,CAAC,aAAa,CAAC;IAC7C,4CAA4C,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAC1D,+BAA+B,CAAC,KAAK,CAAC;CACzC,CAAC;AAIF,MAAM,CAAC,KAAK,UAAU,2BAA2B,CAC/C,OAAqC,EACrC,KAAc;IAEd,MAAM,SAAS,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IAExD,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,MAAM,SAAS,CAAC,KAAc,CAAC,CAAC;AACzC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import readline from "node:readline";
|
|
2
|
+
import { runTaskHelperProcessHandler } from "./task-helper-process-handlers.js";
|
|
3
|
+
const reader = readline.createInterface({
|
|
4
|
+
input: process.stdin,
|
|
5
|
+
crlfDelay: Number.POSITIVE_INFINITY
|
|
6
|
+
});
|
|
7
|
+
reader.on("line", (line) => {
|
|
8
|
+
void handleLine(line);
|
|
9
|
+
});
|
|
10
|
+
async function handleLine(line) {
|
|
11
|
+
const trimmed = line.trim();
|
|
12
|
+
if (!trimmed) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
let payload;
|
|
16
|
+
try {
|
|
17
|
+
payload = JSON.parse(trimmed);
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
writeResponse({
|
|
21
|
+
type: "result",
|
|
22
|
+
id: "unknown",
|
|
23
|
+
ok: false,
|
|
24
|
+
error: error instanceof Error ? error.message : "helper request parse failed"
|
|
25
|
+
});
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
try {
|
|
29
|
+
const result = await runTaskHelperProcessHandler(payload.handler, payload.input);
|
|
30
|
+
writeResponse({
|
|
31
|
+
type: "result",
|
|
32
|
+
id: payload.id,
|
|
33
|
+
ok: true,
|
|
34
|
+
result
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
writeResponse({
|
|
39
|
+
type: "result",
|
|
40
|
+
id: payload.id,
|
|
41
|
+
ok: false,
|
|
42
|
+
error: error instanceof Error ? error.message : "helper task failed"
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
function writeResponse(payload) {
|
|
47
|
+
process.stdout.write(`${JSON.stringify(payload)}\n`);
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=task-helper-process.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-helper-process.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-helper-process.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,eAAe,CAAC;AAErC,OAAO,EACL,2BAA2B,EAE5B,MAAM,mCAAmC,CAAC;AAsB3C,MAAM,MAAM,GAAG,QAAQ,CAAC,eAAe,CAAC;IACtC,KAAK,EAAE,OAAO,CAAC,KAAK;IACpB,SAAS,EAAE,MAAM,CAAC,iBAAiB;CACpC,CAAC,CAAC;AAEH,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;IACzB,KAAK,UAAU,CAAC,IAAI,CAAC,CAAC;AACxB,CAAC,CAAC,CAAC;AAEH,KAAK,UAAU,UAAU,CAAC,IAAY;IACpC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;IAE5B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO;IACT,CAAC;IAED,IAAI,OAA0B,CAAC;IAE/B,IAAI,CAAC;QACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAsB,CAAC;IACrD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,aAAa,CAAC;YACZ,IAAI,EAAE,QAAQ;YACd,EAAE,EAAE,SAAS;YACb,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,6BAA6B;SAC9E,CAAC,CAAC;QACH,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,2BAA2B,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;QACjF,aAAa,CAAC;YACZ,IAAI,EAAE,QAAQ;YACd,EAAE,EAAE,OAAO,CAAC,EAAE;YACd,EAAE,EAAE,IAAI;YACR,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,aAAa,CAAC;YACZ,IAAI,EAAE,QAAQ;YACd,EAAE,EAAE,OAAO,CAAC,EAAE;YACd,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,oBAAoB;SACrE,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED,SAAS,aAAa,CAAC,OAA2B;IAChD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AACvD,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { TaskHelperProcessClient } from "./task-helper-client.js";
|
|
2
|
+
export function createHostTaskLaneExecutors() {
|
|
3
|
+
const helperProcessClient = new TaskHelperProcessClient();
|
|
4
|
+
return {
|
|
5
|
+
helper_process: {
|
|
6
|
+
execute: async (definition, input, context) => {
|
|
7
|
+
if (!definition.helperProcessHandler) {
|
|
8
|
+
return await definition.run(input, context);
|
|
9
|
+
}
|
|
10
|
+
return await helperProcessClient.execute(definition.helperProcessHandler, input, context.signal);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=task-lane-executors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-lane-executors.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-lane-executors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAGlE,MAAM,UAAU,2BAA2B;IACzC,MAAM,mBAAmB,GAAG,IAAI,uBAAuB,EAAE,CAAC;IAE1D,OAAO;QACL,cAAc,EAAE;YACd,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;gBAC5C,IAAI,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC;oBACrC,OAAO,MAAM,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;gBAC9C,CAAC;gBAED,OAAO,MAAM,mBAAmB,CAAC,OAAO,CACtC,UAAU,CAAC,oBAA6B,EACxC,KAAK,EACL,OAAO,CAAC,MAAM,CACf,CAAC;YACJ,CAAC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { TaskActivitySink, TaskDefinition, TaskExecutionLane, TaskEnqueueOptions, TaskHandle, TaskLaneExecutor, TaskMetricsSnapshot, TaskSnapshot } from "./task-types.js";
|
|
2
|
+
export declare class TaskManager {
|
|
3
|
+
private readonly registry;
|
|
4
|
+
private readonly metrics;
|
|
5
|
+
private readonly scheduler;
|
|
6
|
+
constructor(activitySink?: TaskActivitySink | null, laneExecutors?: Partial<Record<TaskExecutionLane, TaskLaneExecutor>>);
|
|
7
|
+
register<TInput, TResult>(definition: TaskDefinition<TInput, TResult>): void;
|
|
8
|
+
has(taskType: string): boolean;
|
|
9
|
+
enqueue<TInput, TResult>(taskType: string, options: TaskEnqueueOptions<TInput>): TaskHandle<TResult>;
|
|
10
|
+
cancel(taskType: string, key: string, reason?: string): void;
|
|
11
|
+
recordCacheHit(taskType: string, key: string): void;
|
|
12
|
+
peek<TResult = unknown>(taskType: string, key: string): TaskSnapshot<TResult> | null;
|
|
13
|
+
observe(): TaskMetricsSnapshot;
|
|
14
|
+
}
|
|
15
|
+
export declare function createTaskManager(activitySink?: TaskActivitySink | null, laneExecutors?: Partial<Record<TaskExecutionLane, TaskLaneExecutor>>): TaskManager;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { TaskMetrics } from "./task-metrics.js";
|
|
2
|
+
import { TaskRegistry } from "./task-registry.js";
|
|
3
|
+
import { TaskScheduler } from "./task-scheduler.js";
|
|
4
|
+
export class TaskManager {
|
|
5
|
+
registry = new TaskRegistry();
|
|
6
|
+
metrics = new TaskMetrics();
|
|
7
|
+
scheduler;
|
|
8
|
+
constructor(activitySink = null, laneExecutors = {}) {
|
|
9
|
+
this.scheduler = new TaskScheduler(this.registry, this.metrics, activitySink, laneExecutors);
|
|
10
|
+
}
|
|
11
|
+
register(definition) {
|
|
12
|
+
this.registry.register(definition);
|
|
13
|
+
}
|
|
14
|
+
has(taskType) {
|
|
15
|
+
return this.registry.has(taskType);
|
|
16
|
+
}
|
|
17
|
+
enqueue(taskType, options) {
|
|
18
|
+
return this.scheduler.enqueue(taskType, options);
|
|
19
|
+
}
|
|
20
|
+
cancel(taskType, key, reason) {
|
|
21
|
+
this.scheduler.cancel(taskType, key, reason);
|
|
22
|
+
}
|
|
23
|
+
recordCacheHit(taskType, key) {
|
|
24
|
+
this.scheduler.recordCacheHit(taskType, key);
|
|
25
|
+
}
|
|
26
|
+
peek(taskType, key) {
|
|
27
|
+
return this.scheduler.peek(taskType, key);
|
|
28
|
+
}
|
|
29
|
+
observe() {
|
|
30
|
+
return this.metrics.observe();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
export function createTaskManager(activitySink = null, laneExecutors = {}) {
|
|
34
|
+
return new TaskManager(activitySink, laneExecutors);
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=task-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-manager.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAYpD,MAAM,OAAO,WAAW;IACL,QAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;IAC9B,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAC5B,SAAS,CAAgB;IAE1C,YACE,eAAwC,IAAI,EAC5C,gBAAsE,EAAE;QAExE,IAAI,CAAC,SAAS,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,aAAa,CAAC,CAAC;IAC/F,CAAC;IAED,QAAQ,CAAkB,UAA2C;QACnE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;IAED,GAAG,CAAC,QAAgB;QAClB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,OAAO,CAAkB,QAAgB,EAAE,OAAmC;QAC5E,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAkB,QAAQ,EAAE,OAAO,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,CAAC,QAAgB,EAAE,GAAW,EAAE,MAAe;QACnD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAC/C,CAAC;IAED,cAAc,CAAC,QAAgB,EAAE,GAAW;QAC1C,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED,IAAI,CAAoB,QAAgB,EAAE,GAAW;QACnD,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAU,QAAQ,EAAE,GAAG,CAAC,CAAC;IACrD,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;CACF;AAED,MAAM,UAAU,iBAAiB,CAC/B,eAAwC,IAAI,EAC5C,gBAAsE,EAAE;IAExE,OAAO,IAAI,WAAW,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC;AACtD,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TaskCounterMetricName, TaskDurationMetricName, TaskExecutionLane, TaskMetricsSnapshot } from "./task-types.js";
|
|
2
|
+
export declare class TaskMetrics {
|
|
3
|
+
private readonly totals;
|
|
4
|
+
private readonly taskTypes;
|
|
5
|
+
increment(taskType: string, executionLane: TaskExecutionLane, metric: TaskCounterMetricName): void;
|
|
6
|
+
recordDuration(taskType: string, executionLane: TaskExecutionLane, metric: TaskDurationMetricName, valueMs: number): void;
|
|
7
|
+
observe(): TaskMetricsSnapshot;
|
|
8
|
+
private getTaskGroup;
|
|
9
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
const COUNTER_METRIC_NAMES = [
|
|
2
|
+
"enqueue",
|
|
3
|
+
"dedupe",
|
|
4
|
+
"started",
|
|
5
|
+
"finished",
|
|
6
|
+
"failed",
|
|
7
|
+
"cancelled",
|
|
8
|
+
"timeout",
|
|
9
|
+
"cache_hit"
|
|
10
|
+
];
|
|
11
|
+
export class TaskMetrics {
|
|
12
|
+
totals = createCounterRecord();
|
|
13
|
+
taskTypes = new Map();
|
|
14
|
+
increment(taskType, executionLane, metric) {
|
|
15
|
+
this.totals[metric] += 1;
|
|
16
|
+
this.getTaskGroup(taskType, executionLane).counters[metric] += 1;
|
|
17
|
+
}
|
|
18
|
+
recordDuration(taskType, executionLane, metric, valueMs) {
|
|
19
|
+
const normalized = Math.max(0, valueMs);
|
|
20
|
+
const stats = metric === "wait_ms"
|
|
21
|
+
? this.getTaskGroup(taskType, executionLane).waitMs
|
|
22
|
+
: this.getTaskGroup(taskType, executionLane).runMs;
|
|
23
|
+
stats.count += 1;
|
|
24
|
+
stats.total += normalized;
|
|
25
|
+
stats.max = Math.max(stats.max, normalized);
|
|
26
|
+
stats.min = stats.min === null ? normalized : Math.min(stats.min, normalized);
|
|
27
|
+
}
|
|
28
|
+
observe() {
|
|
29
|
+
const taskTypes = Object.fromEntries([...this.taskTypes.entries()].map(([taskType, group]) => [
|
|
30
|
+
taskType,
|
|
31
|
+
{
|
|
32
|
+
executionLane: group.executionLane,
|
|
33
|
+
counters: { ...group.counters },
|
|
34
|
+
waitMs: snapshotDurationStats(group.waitMs),
|
|
35
|
+
runMs: snapshotDurationStats(group.runMs)
|
|
36
|
+
}
|
|
37
|
+
]));
|
|
38
|
+
return {
|
|
39
|
+
totals: { ...this.totals },
|
|
40
|
+
taskTypes
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
getTaskGroup(taskType, executionLane) {
|
|
44
|
+
const existing = this.taskTypes.get(taskType);
|
|
45
|
+
if (existing) {
|
|
46
|
+
return existing;
|
|
47
|
+
}
|
|
48
|
+
const created = {
|
|
49
|
+
executionLane,
|
|
50
|
+
counters: createCounterRecord(),
|
|
51
|
+
waitMs: createDurationStats(),
|
|
52
|
+
runMs: createDurationStats()
|
|
53
|
+
};
|
|
54
|
+
this.taskTypes.set(taskType, created);
|
|
55
|
+
return created;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
function createCounterRecord() {
|
|
59
|
+
return COUNTER_METRIC_NAMES.reduce((result, metric) => {
|
|
60
|
+
result[metric] = 0;
|
|
61
|
+
return result;
|
|
62
|
+
}, {});
|
|
63
|
+
}
|
|
64
|
+
function createDurationStats() {
|
|
65
|
+
return {
|
|
66
|
+
count: 0,
|
|
67
|
+
total: 0,
|
|
68
|
+
max: 0,
|
|
69
|
+
min: null
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
function snapshotDurationStats(stats) {
|
|
73
|
+
return {
|
|
74
|
+
count: stats.count,
|
|
75
|
+
total: stats.total,
|
|
76
|
+
max: stats.max,
|
|
77
|
+
min: stats.min,
|
|
78
|
+
avg: stats.count > 0 ? stats.total / stats.count : 0
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=task-metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-metrics.js","sourceRoot":"","sources":["../../../../src/modules/tasks/task-metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { TaskDefinition } from "./task-types.js";
|
|
2
|
+
export declare class TaskRegistry {
|
|
3
|
+
private readonly definitions;
|
|
4
|
+
register<TInput, TResult>(definition: TaskDefinition<TInput, TResult>): void;
|
|
5
|
+
has(taskType: string): boolean;
|
|
6
|
+
get<TInput, TResult>(taskType: string): TaskDefinition<TInput, TResult>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export class TaskRegistry {
|
|
2
|
+
definitions = new Map();
|
|
3
|
+
register(definition) {
|
|
4
|
+
const existing = this.definitions.get(definition.taskType);
|
|
5
|
+
if (existing && existing !== definition) {
|
|
6
|
+
throw new Error(`任务类型已注册: ${definition.taskType}`);
|
|
7
|
+
}
|
|
8
|
+
this.definitions.set(definition.taskType, definition);
|
|
9
|
+
}
|
|
10
|
+
has(taskType) {
|
|
11
|
+
return this.definitions.has(taskType);
|
|
12
|
+
}
|
|
13
|
+
get(taskType) {
|
|
14
|
+
const definition = this.definitions.get(taskType);
|
|
15
|
+
if (!definition) {
|
|
16
|
+
throw new Error(`未注册的任务类型: ${taskType}`);
|
|
17
|
+
}
|
|
18
|
+
return definition;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=task-registry.js.map
|