@jingyi0605/codingns 0.1.5 → 0.2.5
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 +640 -53
- package/dist/public/assets/{TerminalPage-4p6EBqrR.js → TerminalPage-BkjqU9NG.js} +19 -19
- package/dist/public/assets/index-C6U8-9jg.css +1 -0
- package/dist/public/assets/index-CKSumuV2.js +109 -0
- package/dist/public/index.html +2 -2
- package/dist/server/config/env.d.ts +2 -0
- package/dist/server/config/env.js +8 -1
- 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.js +69 -30
- 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 +2 -1
- package/dist/server/modules/butler/butler-session-service.js +10 -1
- 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 +102 -0
- package/dist/server/modules/debug-target/debug-target-service.js +1484 -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-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.d.ts +12 -1
- package/dist/server/modules/file/file-controller.js +72 -1
- package/dist/server/modules/file/file-controller.js.map +1 -1
- package/dist/server/modules/file/file-preview-link-service.d.ts +22 -0
- package/dist/server/modules/file/file-preview-link-service.js +160 -0
- package/dist/server/modules/file/file-preview-link-service.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 +6 -0
- package/dist/server/modules/git/git-controller.js +5 -1
- package/dist/server/modules/git/git-controller.js.map +1 -1
- package/dist/server/modules/git/git-read-service.d.ts +2 -1
- package/dist/server/modules/git/git-read-service.js +19 -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 +3 -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/codex-app-server-helper-client.d.ts +2 -1
- package/dist/server/modules/sessions/codex-app-server-helper-client.js +103 -0
- package/dist/server/modules/sessions/codex-app-server-helper-client.js.map +1 -1
- package/dist/server/modules/sessions/codex-app-server-helper-process.js +106 -1
- package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
- package/dist/server/modules/sessions/session-controller.d.ts +26 -0
- package/dist/server/modules/sessions/session-controller.js +39 -1
- package/dist/server/modules/sessions/session-controller.js.map +1 -1
- package/dist/server/modules/sessions/session-history-service.d.ts +51 -5
- package/dist/server/modules/sessions/session-history-service.js +906 -59
- package/dist/server/modules/sessions/session-history-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-service.d.ts +5 -0
- package/dist/server/modules/sessions/session-live-runtime-service.js +59 -2
- package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-error-mapper.js +66 -0
- package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
- 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/files.js +2 -0
- package/dist/server/routes/files.js.map +1 -1
- package/dist/server/routes/git.js +1 -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/sessions.js +1 -0
- package/dist/server/routes/sessions.js.map +1 -1
- 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 +38 -0
- package/dist/server/server/create-server.js +106 -11
- 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 +83 -0
- package/dist/server/shared/utils/command-availability.js.map +1 -0
- 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/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/session-fork-repository.d.ts +8 -0
- package/dist/server/storage/repositories/session-fork-repository.js +69 -0
- package/dist/server/storage/repositories/session-fork-repository.js.map +1 -0
- package/dist/server/storage/repositories/session-index-repository.js +40 -2
- package/dist/server/storage/repositories/session-index-repository.js.map +1 -1
- 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 +408 -0
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +268 -0
- package/dist/server/types/domain.d.ts +256 -1
- package/dist/server/ws/workbench-ws-hub.js +33 -9
- package/dist/server/ws/workbench-ws-hub.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.d.ts +6 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +240 -7
- 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.d.ts +26 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +507 -2
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +94 -5
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.d.ts +5 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +293 -3
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +117 -17
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +10 -0
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +128 -8
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/services.d.ts +2 -1
- package/node_modules/@codingns/session-sync-core/dist/services.js +55 -8
- package/node_modules/@codingns/session-sync-core/dist/services.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/types.d.ts +33 -0
- package/package.json +1 -1
- package/dist/public/assets/index-CxeghocY.css +0 -1
- package/dist/public/assets/index-DXusStl0.js +0 -108
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { TaskMetricsSnapshot } from "./task-types.js";
|
|
2
|
+
import type { SchedulerMetricsSnapshot } from "./scheduler-metrics.js";
|
|
3
|
+
import type { EventLoopDelaySnapshot, EventLoopMonitor } from "./event-loop-monitor.js";
|
|
4
|
+
import type { TaskActivityLog, TaskActivityRecord } from "./task-activity-log.js";
|
|
5
|
+
export interface RuntimeObservabilitySessionLease {
|
|
6
|
+
readonly sessionId: string;
|
|
7
|
+
readonly expiresAt: string;
|
|
8
|
+
readonly ttlMs: number;
|
|
9
|
+
}
|
|
10
|
+
export interface RuntimeObservabilitySnapshot {
|
|
11
|
+
readonly observedAt: string;
|
|
12
|
+
readonly session: RuntimeObservabilitySessionLease;
|
|
13
|
+
readonly backgroundTasks: TaskMetricsSnapshot;
|
|
14
|
+
readonly recentTaskActivities: TaskActivityRecord[];
|
|
15
|
+
readonly schedulers: SchedulerMetricsSnapshot;
|
|
16
|
+
readonly eventLoop: EventLoopDelaySnapshot;
|
|
17
|
+
}
|
|
18
|
+
export declare class RuntimeObservabilityService {
|
|
19
|
+
private readonly getTaskMetrics;
|
|
20
|
+
private readonly getSchedulerMetrics;
|
|
21
|
+
private readonly eventLoopMonitor;
|
|
22
|
+
private readonly taskActivityLog;
|
|
23
|
+
private readonly sessions;
|
|
24
|
+
constructor(getTaskMetrics: () => TaskMetricsSnapshot, getSchedulerMetrics: () => SchedulerMetricsSnapshot, eventLoopMonitor: EventLoopMonitor, taskActivityLog: TaskActivityLog);
|
|
25
|
+
hasActiveSession(): boolean;
|
|
26
|
+
openSession(ttlMs?: number): RuntimeObservabilitySessionLease;
|
|
27
|
+
touchSession(sessionId: string, ttlMs?: number): RuntimeObservabilitySessionLease;
|
|
28
|
+
closeSession(sessionId: string): void;
|
|
29
|
+
observe(sessionId: string, activityLimit?: number): RuntimeObservabilitySnapshot;
|
|
30
|
+
private pruneExpiredSessions;
|
|
31
|
+
private syncCollectors;
|
|
32
|
+
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { createId } from "../../shared/utils/id.js";
|
|
2
|
+
import { nowIso } from "../../shared/utils/time.js";
|
|
3
|
+
import { AppError } from "../../shared/errors/app-error.js";
|
|
4
|
+
const DEFAULT_SESSION_TTL_MS = 20_000;
|
|
5
|
+
const MIN_SESSION_TTL_MS = 5_000;
|
|
6
|
+
const MAX_SESSION_TTL_MS = 120_000;
|
|
7
|
+
export class RuntimeObservabilityService {
|
|
8
|
+
getTaskMetrics;
|
|
9
|
+
getSchedulerMetrics;
|
|
10
|
+
eventLoopMonitor;
|
|
11
|
+
taskActivityLog;
|
|
12
|
+
sessions = new Map();
|
|
13
|
+
constructor(getTaskMetrics, getSchedulerMetrics, eventLoopMonitor, taskActivityLog) {
|
|
14
|
+
this.getTaskMetrics = getTaskMetrics;
|
|
15
|
+
this.getSchedulerMetrics = getSchedulerMetrics;
|
|
16
|
+
this.eventLoopMonitor = eventLoopMonitor;
|
|
17
|
+
this.taskActivityLog = taskActivityLog;
|
|
18
|
+
}
|
|
19
|
+
hasActiveSession() {
|
|
20
|
+
this.pruneExpiredSessions();
|
|
21
|
+
return this.sessions.size > 0;
|
|
22
|
+
}
|
|
23
|
+
openSession(ttlMs) {
|
|
24
|
+
this.pruneExpiredSessions();
|
|
25
|
+
const normalizedTtlMs = normalizeSessionTtlMs(ttlMs);
|
|
26
|
+
const sessionId = createId();
|
|
27
|
+
const expiresAtMs = Date.now() + normalizedTtlMs;
|
|
28
|
+
this.sessions.set(sessionId, {
|
|
29
|
+
expiresAtMs,
|
|
30
|
+
ttlMs: normalizedTtlMs
|
|
31
|
+
});
|
|
32
|
+
this.syncCollectors();
|
|
33
|
+
return buildLease(sessionId, expiresAtMs, normalizedTtlMs);
|
|
34
|
+
}
|
|
35
|
+
touchSession(sessionId, ttlMs) {
|
|
36
|
+
this.pruneExpiredSessions();
|
|
37
|
+
const session = this.sessions.get(sessionId);
|
|
38
|
+
if (!session) {
|
|
39
|
+
throw new AppError({
|
|
40
|
+
statusCode: 404,
|
|
41
|
+
errorCode: "OBSERVABILITY_SESSION_NOT_FOUND",
|
|
42
|
+
detail: "观测会话不存在或已过期"
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
const normalizedTtlMs = normalizeSessionTtlMs(ttlMs ?? session.ttlMs);
|
|
46
|
+
session.ttlMs = normalizedTtlMs;
|
|
47
|
+
session.expiresAtMs = Date.now() + normalizedTtlMs;
|
|
48
|
+
this.sessions.set(sessionId, session);
|
|
49
|
+
this.syncCollectors();
|
|
50
|
+
return buildLease(sessionId, session.expiresAtMs, normalizedTtlMs);
|
|
51
|
+
}
|
|
52
|
+
closeSession(sessionId) {
|
|
53
|
+
this.pruneExpiredSessions();
|
|
54
|
+
this.sessions.delete(sessionId);
|
|
55
|
+
this.syncCollectors();
|
|
56
|
+
}
|
|
57
|
+
observe(sessionId, activityLimit = 100) {
|
|
58
|
+
const session = this.touchSession(sessionId);
|
|
59
|
+
return {
|
|
60
|
+
observedAt: nowIso(),
|
|
61
|
+
session,
|
|
62
|
+
backgroundTasks: this.getTaskMetrics(),
|
|
63
|
+
recentTaskActivities: this.taskActivityLog.list(activityLimit),
|
|
64
|
+
schedulers: this.getSchedulerMetrics(),
|
|
65
|
+
eventLoop: this.eventLoopMonitor.observe()
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
pruneExpiredSessions() {
|
|
69
|
+
const now = Date.now();
|
|
70
|
+
let changed = false;
|
|
71
|
+
for (const [sessionId, session] of this.sessions.entries()) {
|
|
72
|
+
if (session.expiresAtMs > now) {
|
|
73
|
+
continue;
|
|
74
|
+
}
|
|
75
|
+
this.sessions.delete(sessionId);
|
|
76
|
+
changed = true;
|
|
77
|
+
}
|
|
78
|
+
if (changed) {
|
|
79
|
+
this.syncCollectors();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
syncCollectors() {
|
|
83
|
+
if (this.sessions.size > 0) {
|
|
84
|
+
this.eventLoopMonitor.start();
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
this.taskActivityLog.clear();
|
|
88
|
+
this.eventLoopMonitor.stop();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
function normalizeSessionTtlMs(value) {
|
|
92
|
+
if (!value || !Number.isFinite(value)) {
|
|
93
|
+
return DEFAULT_SESSION_TTL_MS;
|
|
94
|
+
}
|
|
95
|
+
return Math.min(MAX_SESSION_TTL_MS, Math.max(MIN_SESSION_TTL_MS, Math.floor(value)));
|
|
96
|
+
}
|
|
97
|
+
function buildLease(sessionId, expiresAtMs, ttlMs) {
|
|
98
|
+
return {
|
|
99
|
+
sessionId,
|
|
100
|
+
expiresAt: new Date(expiresAtMs).toISOString(),
|
|
101
|
+
ttlMs
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=observability-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"observability-service.js","sourceRoot":"","sources":["../../../../src/modules/tasks/observability-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
export interface SchedulerDurationStatsSnapshot {
|
|
2
|
+
readonly count: number;
|
|
3
|
+
readonly total: number;
|
|
4
|
+
readonly max: number;
|
|
5
|
+
readonly min: number | null;
|
|
6
|
+
readonly avg: number;
|
|
7
|
+
}
|
|
8
|
+
export interface SchedulerMetricSnapshot {
|
|
9
|
+
readonly tickTotal: number;
|
|
10
|
+
readonly idleTickTotal: number;
|
|
11
|
+
readonly errorTotal: number;
|
|
12
|
+
readonly taskCountTotal: number;
|
|
13
|
+
readonly durationMs: SchedulerDurationStatsSnapshot;
|
|
14
|
+
readonly lastTickAt: string | null;
|
|
15
|
+
readonly lastDurationMs: number | null;
|
|
16
|
+
readonly lastTaskCount: number;
|
|
17
|
+
readonly lastIdle: boolean;
|
|
18
|
+
readonly lastErrorCount: number;
|
|
19
|
+
readonly nextDelayMs: number | null;
|
|
20
|
+
readonly idleStreak: number;
|
|
21
|
+
}
|
|
22
|
+
export interface SchedulerMetricsSnapshot {
|
|
23
|
+
readonly schedulers: Readonly<Record<string, SchedulerMetricSnapshot>>;
|
|
24
|
+
}
|
|
25
|
+
export interface SchedulerTickObservation {
|
|
26
|
+
readonly schedulerName: string;
|
|
27
|
+
readonly referenceAt: string;
|
|
28
|
+
readonly durationMs: number;
|
|
29
|
+
readonly taskCount: number;
|
|
30
|
+
readonly idle: boolean;
|
|
31
|
+
readonly errorCount?: number;
|
|
32
|
+
readonly nextDelayMs?: number | null;
|
|
33
|
+
readonly idleStreak?: number;
|
|
34
|
+
}
|
|
35
|
+
export declare class SchedulerMetrics {
|
|
36
|
+
private readonly schedulers;
|
|
37
|
+
recordTick(observation: SchedulerTickObservation): void;
|
|
38
|
+
observe(): SchedulerMetricsSnapshot;
|
|
39
|
+
private getState;
|
|
40
|
+
}
|
|
41
|
+
export declare function resolveAdaptiveSchedulerDelayMs(baseIntervalMs: number, maxIntervalMs: number, idleStreak: number): number;
|
|
@@ -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"}
|