hivehq 2.0.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/CHANGELOG.md +592 -0
- package/LICENSE +208 -0
- package/LICENSE.BSL +101 -0
- package/NOTICE +15 -0
- package/README.en.md +451 -0
- package/README.md +329 -0
- package/SECURITY.md +59 -0
- package/TRADEMARK.md +41 -0
- package/assets/hive-hero.png +0 -0
- package/assets/hive-team-view.png +0 -0
- package/assets/logo.png +0 -0
- package/assets/qq-group.jpg +0 -0
- package/dist/bin/team +7 -0
- package/dist/bin/team.cmd +3 -0
- package/dist/src/cli/hive-remote.d.ts +46 -0
- package/dist/src/cli/hive-remote.js +257 -0
- package/dist/src/cli/hive-update.d.ts +75 -0
- package/dist/src/cli/hive-update.js +215 -0
- package/dist/src/cli/hive.d.ts +78 -0
- package/dist/src/cli/hive.js +336 -0
- package/dist/src/cli/team.d.ts +38 -0
- package/dist/src/cli/team.js +762 -0
- package/dist/src/server/agent-command-resolver.d.ts +17 -0
- package/dist/src/server/agent-command-resolver.js +106 -0
- package/dist/src/server/agent-exit-classification.d.ts +6 -0
- package/dist/src/server/agent-exit-classification.js +6 -0
- package/dist/src/server/agent-launch-cache.d.ts +20 -0
- package/dist/src/server/agent-launch-cache.js +75 -0
- package/dist/src/server/agent-launch-resolver.d.ts +4 -0
- package/dist/src/server/agent-launch-resolver.js +38 -0
- package/dist/src/server/agent-manager-support.d.ts +36 -0
- package/dist/src/server/agent-manager-support.js +318 -0
- package/dist/src/server/agent-manager.d.ts +54 -0
- package/dist/src/server/agent-manager.js +104 -0
- package/dist/src/server/agent-run-bootstrap.d.ts +83 -0
- package/dist/src/server/agent-run-bootstrap.js +101 -0
- package/dist/src/server/agent-run-exit-handler.d.ts +8 -0
- package/dist/src/server/agent-run-exit-handler.js +32 -0
- package/dist/src/server/agent-run-start-context.d.ts +24 -0
- package/dist/src/server/agent-run-start-context.js +1 -0
- package/dist/src/server/agent-run-starter.d.ts +30 -0
- package/dist/src/server/agent-run-starter.js +155 -0
- package/dist/src/server/agent-run-store.d.ts +51 -0
- package/dist/src/server/agent-run-store.js +137 -0
- package/dist/src/server/agent-run-sync.d.ts +10 -0
- package/dist/src/server/agent-run-sync.js +32 -0
- package/dist/src/server/agent-runtime-active-run.d.ts +3 -0
- package/dist/src/server/agent-runtime-active-run.js +10 -0
- package/dist/src/server/agent-runtime-close.d.ts +5 -0
- package/dist/src/server/agent-runtime-close.js +36 -0
- package/dist/src/server/agent-runtime-contract.d.ts +48 -0
- package/dist/src/server/agent-runtime-contract.js +1 -0
- package/dist/src/server/agent-runtime-flow-adapter.d.ts +10 -0
- package/dist/src/server/agent-runtime-flow-adapter.js +14 -0
- package/dist/src/server/agent-runtime-list-runs.d.ts +3 -0
- package/dist/src/server/agent-runtime-list-runs.js +18 -0
- package/dist/src/server/agent-runtime-ports.d.ts +22 -0
- package/dist/src/server/agent-runtime-ports.js +1 -0
- package/dist/src/server/agent-runtime-stop-run.d.ts +4 -0
- package/dist/src/server/agent-runtime-stop-run.js +19 -0
- package/dist/src/server/agent-runtime-types.d.ts +5 -0
- package/dist/src/server/agent-runtime-types.js +1 -0
- package/dist/src/server/agent-runtime.d.ts +10 -0
- package/dist/src/server/agent-runtime.js +143 -0
- package/dist/src/server/agent-session-store.d.ts +7 -0
- package/dist/src/server/agent-session-store.js +45 -0
- package/dist/src/server/agent-startup-instructions.d.ts +20 -0
- package/dist/src/server/agent-startup-instructions.js +36 -0
- package/dist/src/server/agent-stdin-dispatcher.d.ts +52 -0
- package/dist/src/server/agent-stdin-dispatcher.js +224 -0
- package/dist/src/server/agent-tokens.d.ts +15 -0
- package/dist/src/server/agent-tokens.js +25 -0
- package/dist/src/server/app-state-store.d.ts +10 -0
- package/dist/src/server/app-state-store.js +12 -0
- package/dist/src/server/app.d.ts +20 -0
- package/dist/src/server/app.js +211 -0
- package/dist/src/server/claude-command-defaults.d.ts +1 -0
- package/dist/src/server/claude-command-defaults.js +5 -0
- package/dist/src/server/claude-session-coordinator.d.ts +10 -0
- package/dist/src/server/claude-session-coordinator.js +68 -0
- package/dist/src/server/claude-session-support.d.ts +1 -0
- package/dist/src/server/claude-session-support.js +1 -0
- package/dist/src/server/command-preset-defaults.d.ts +11 -0
- package/dist/src/server/command-preset-defaults.js +63 -0
- package/dist/src/server/command-preset-store.d.ts +49 -0
- package/dist/src/server/command-preset-store.js +83 -0
- package/dist/src/server/cron-util.d.ts +7 -0
- package/dist/src/server/cron-util.js +19 -0
- package/dist/src/server/dispatch-ledger-serializer.d.ts +15 -0
- package/dist/src/server/dispatch-ledger-serializer.js +14 -0
- package/dist/src/server/dispatch-ledger-store.d.ts +108 -0
- package/dist/src/server/dispatch-ledger-store.js +241 -0
- package/dist/src/server/env-sync-message.d.ts +9 -0
- package/dist/src/server/env-sync-message.js +29 -0
- package/dist/src/server/feature-flags.d.ts +42 -0
- package/dist/src/server/feature-flags.js +24 -0
- package/dist/src/server/fs-browse.d.ts +40 -0
- package/dist/src/server/fs-browse.js +306 -0
- package/dist/src/server/fs-pick-folder.d.ts +25 -0
- package/dist/src/server/fs-pick-folder.js +115 -0
- package/dist/src/server/fs-sandbox.d.ts +15 -0
- package/dist/src/server/fs-sandbox.js +56 -0
- package/dist/src/server/hive-team-guidance.d.ts +39 -0
- package/dist/src/server/hive-team-guidance.js +295 -0
- package/dist/src/server/http-errors.d.ts +22 -0
- package/dist/src/server/http-errors.js +44 -0
- package/dist/src/server/live-run-registry.d.ts +22 -0
- package/dist/src/server/live-run-registry.js +52 -0
- package/dist/src/server/local-request-guard.d.ts +3 -0
- package/dist/src/server/local-request-guard.js +41 -0
- package/dist/src/server/machine-name.d.ts +2 -0
- package/dist/src/server/machine-name.js +13 -0
- package/dist/src/server/marketplace-store.d.ts +38 -0
- package/dist/src/server/marketplace-store.js +85 -0
- package/dist/src/server/message-log-store.d.ts +51 -0
- package/dist/src/server/message-log-store.js +90 -0
- package/dist/src/server/open-target-commands.d.ts +54 -0
- package/dist/src/server/open-target-commands.js +204 -0
- package/dist/src/server/orchestrator-autostart.d.ts +42 -0
- package/dist/src/server/orchestrator-autostart.js +114 -0
- package/dist/src/server/orchestrator-launch.d.ts +24 -0
- package/dist/src/server/orchestrator-launch.js +71 -0
- package/dist/src/server/package-version.d.ts +17 -0
- package/dist/src/server/package-version.js +32 -0
- package/dist/src/server/path-canonicalization.d.ts +3 -0
- package/dist/src/server/path-canonicalization.js +29 -0
- package/dist/src/server/platform-path.d.ts +4 -0
- package/dist/src/server/platform-path.js +26 -0
- package/dist/src/server/post-start-input-writer.d.ts +6 -0
- package/dist/src/server/post-start-input-writer.js +242 -0
- package/dist/src/server/preset-launch-support.d.ts +6 -0
- package/dist/src/server/preset-launch-support.js +98 -0
- package/dist/src/server/pty-output-bus.d.ts +8 -0
- package/dist/src/server/pty-output-bus.js +32 -0
- package/dist/src/server/recovery-summary.d.ts +15 -0
- package/dist/src/server/recovery-summary.js +92 -0
- package/dist/src/server/remote-audit-store.d.ts +51 -0
- package/dist/src/server/remote-audit-store.js +108 -0
- package/dist/src/server/remote-config-keys.d.ts +17 -0
- package/dist/src/server/remote-config-keys.js +27 -0
- package/dist/src/server/remote-control-constants.d.ts +30 -0
- package/dist/src/server/remote-control-constants.js +29 -0
- package/dist/src/server/remote-device-session.d.ts +40 -0
- package/dist/src/server/remote-device-session.js +22 -0
- package/dist/src/server/remote-device-store.d.ts +36 -0
- package/dist/src/server/remote-device-store.js +67 -0
- package/dist/src/server/remote-frame-bridge.d.ts +102 -0
- package/dist/src/server/remote-frame-bridge.js +791 -0
- package/dist/src/server/remote-gateway-client.d.ts +14 -0
- package/dist/src/server/remote-gateway-client.js +36 -0
- package/dist/src/server/remote-loopback-auth.d.ts +6 -0
- package/dist/src/server/remote-loopback-auth.js +112 -0
- package/dist/src/server/remote-pairing-tunnel.d.ts +59 -0
- package/dist/src/server/remote-pairing-tunnel.js +146 -0
- package/dist/src/server/remote-pairing.d.ts +58 -0
- package/dist/src/server/remote-pairing.js +237 -0
- package/dist/src/server/remote-tunnel.d.ts +113 -0
- package/dist/src/server/remote-tunnel.js +514 -0
- package/dist/src/server/report-outbox-store.d.ts +36 -0
- package/dist/src/server/report-outbox-store.js +33 -0
- package/dist/src/server/restart-policy-support.d.ts +30 -0
- package/dist/src/server/restart-policy-support.js +21 -0
- package/dist/src/server/restart-policy.d.ts +18 -0
- package/dist/src/server/restart-policy.js +77 -0
- package/dist/src/server/role-template-store.d.ts +45 -0
- package/dist/src/server/role-template-store.js +76 -0
- package/dist/src/server/role-templates.d.ts +7 -0
- package/dist/src/server/role-templates.js +54 -0
- package/dist/src/server/route-helpers.d.ts +9 -0
- package/dist/src/server/route-helpers.js +61 -0
- package/dist/src/server/route-types.d.ts +121 -0
- package/dist/src/server/route-types.js +1 -0
- package/dist/src/server/routes-dispatches.d.ts +2 -0
- package/dist/src/server/routes-dispatches.js +54 -0
- package/dist/src/server/routes-fs.d.ts +2 -0
- package/dist/src/server/routes-fs.js +24 -0
- package/dist/src/server/routes-marketplace.d.ts +2 -0
- package/dist/src/server/routes-marketplace.js +54 -0
- package/dist/src/server/routes-open-workspace.d.ts +2 -0
- package/dist/src/server/routes-open-workspace.js +47 -0
- package/dist/src/server/routes-remote.d.ts +2 -0
- package/dist/src/server/routes-remote.js +166 -0
- package/dist/src/server/routes-runtime.d.ts +2 -0
- package/dist/src/server/routes-runtime.js +79 -0
- package/dist/src/server/routes-settings.d.ts +2 -0
- package/dist/src/server/routes-settings.js +213 -0
- package/dist/src/server/routes-tasks.d.ts +2 -0
- package/dist/src/server/routes-tasks.js +47 -0
- package/dist/src/server/routes-team-memory.d.ts +2 -0
- package/dist/src/server/routes-team-memory.js +154 -0
- package/dist/src/server/routes-team-recall.d.ts +2 -0
- package/dist/src/server/routes-team-recall.js +119 -0
- package/dist/src/server/routes-team.d.ts +2 -0
- package/dist/src/server/routes-team.js +351 -0
- package/dist/src/server/routes-ui.d.ts +2 -0
- package/dist/src/server/routes-ui.js +17 -0
- package/dist/src/server/routes-version.d.ts +2 -0
- package/dist/src/server/routes-version.js +6 -0
- package/dist/src/server/routes-workflow-schedules.d.ts +2 -0
- package/dist/src/server/routes-workflow-schedules.js +58 -0
- package/dist/src/server/routes-workflows.d.ts +2 -0
- package/dist/src/server/routes-workflows.js +83 -0
- package/dist/src/server/routes-workspace-memory-dreams.d.ts +2 -0
- package/dist/src/server/routes-workspace-memory-dreams.js +105 -0
- package/dist/src/server/routes-workspace-memory.d.ts +2 -0
- package/dist/src/server/routes-workspace-memory.js +215 -0
- package/dist/src/server/routes-workspaces.d.ts +2 -0
- package/dist/src/server/routes-workspaces.js +177 -0
- package/dist/src/server/routes.d.ts +6 -0
- package/dist/src/server/routes.js +55 -0
- package/dist/src/server/runtime-database.d.ts +3 -0
- package/dist/src/server/runtime-database.js +41 -0
- package/dist/src/server/runtime-message-builders.d.ts +7 -0
- package/dist/src/server/runtime-message-builders.js +60 -0
- package/dist/src/server/runtime-restart-policy.d.ts +18 -0
- package/dist/src/server/runtime-restart-policy.js +12 -0
- package/dist/src/server/runtime-store-contract.d.ts +162 -0
- package/dist/src/server/runtime-store-contract.js +1 -0
- package/dist/src/server/runtime-store-dream.d.ts +23 -0
- package/dist/src/server/runtime-store-dream.js +16 -0
- package/dist/src/server/runtime-store-helpers.d.ts +115 -0
- package/dist/src/server/runtime-store-helpers.js +411 -0
- package/dist/src/server/runtime-store-memory.d.ts +33 -0
- package/dist/src/server/runtime-store-memory.js +37 -0
- package/dist/src/server/runtime-store-remote.d.ts +5 -0
- package/dist/src/server/runtime-store-remote.js +45 -0
- package/dist/src/server/runtime-store-workflows.d.ts +6 -0
- package/dist/src/server/runtime-store-workflows.js +108 -0
- package/dist/src/server/runtime-store.d.ts +4 -0
- package/dist/src/server/runtime-store.js +165 -0
- package/dist/src/server/session-capture-claude.d.ts +34 -0
- package/dist/src/server/session-capture-claude.js +103 -0
- package/dist/src/server/session-capture-codex.d.ts +6 -0
- package/dist/src/server/session-capture-codex.js +108 -0
- package/dist/src/server/session-capture-gemini.d.ts +5 -0
- package/dist/src/server/session-capture-gemini.js +81 -0
- package/dist/src/server/session-capture-opencode.d.ts +22 -0
- package/dist/src/server/session-capture-opencode.js +75 -0
- package/dist/src/server/session-capture.d.ts +77 -0
- package/dist/src/server/session-capture.js +123 -0
- package/dist/src/server/settings-store.d.ts +22 -0
- package/dist/src/server/settings-store.js +22 -0
- package/dist/src/server/sqlite-schema-v10.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v10.js +13 -0
- package/dist/src/server/sqlite-schema-v11.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v11.js +10 -0
- package/dist/src/server/sqlite-schema-v12.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v12.js +21 -0
- package/dist/src/server/sqlite-schema-v13.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v13.js +4 -0
- package/dist/src/server/sqlite-schema-v14.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v14.js +84 -0
- package/dist/src/server/sqlite-schema-v15.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v15.js +73 -0
- package/dist/src/server/sqlite-schema-v16.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v16.js +6 -0
- package/dist/src/server/sqlite-schema-v17.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v17.js +15 -0
- package/dist/src/server/sqlite-schema-v18.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v18.js +6 -0
- package/dist/src/server/sqlite-schema-v19.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v19.js +17 -0
- package/dist/src/server/sqlite-schema-v20.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v20.js +20 -0
- package/dist/src/server/sqlite-schema-v21.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v21.js +20 -0
- package/dist/src/server/sqlite-schema-v22.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v22.js +27 -0
- package/dist/src/server/sqlite-schema-v23.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v23.js +43 -0
- package/dist/src/server/sqlite-schema-v24.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v24.js +34 -0
- package/dist/src/server/sqlite-schema-v25.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v25.js +127 -0
- package/dist/src/server/sqlite-schema-v26.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v26.js +56 -0
- package/dist/src/server/sqlite-schema-v27.d.ts +6 -0
- package/dist/src/server/sqlite-schema-v27.js +92 -0
- package/dist/src/server/sqlite-schema-v28.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v28.js +19 -0
- package/dist/src/server/sqlite-schema-v5.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v5.js +61 -0
- package/dist/src/server/sqlite-schema-v7.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v7.js +70 -0
- package/dist/src/server/sqlite-schema-v8.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v8.js +6 -0
- package/dist/src/server/sqlite-schema-v9.d.ts +2 -0
- package/dist/src/server/sqlite-schema-v9.js +6 -0
- package/dist/src/server/sqlite-schema.d.ts +3 -0
- package/dist/src/server/sqlite-schema.js +353 -0
- package/dist/src/server/startup-command-parser.d.ts +20 -0
- package/dist/src/server/startup-command-parser.js +72 -0
- package/dist/src/server/system-message.d.ts +8 -0
- package/dist/src/server/system-message.js +8 -0
- package/dist/src/server/task-deps.d.ts +32 -0
- package/dist/src/server/task-deps.js +40 -0
- package/dist/src/server/tasks-file-watcher.d.ts +47 -0
- package/dist/src/server/tasks-file-watcher.js +200 -0
- package/dist/src/server/tasks-file.d.ts +23 -0
- package/dist/src/server/tasks-file.js +101 -0
- package/dist/src/server/tasks-websocket-server.d.ts +8 -0
- package/dist/src/server/tasks-websocket-server.js +95 -0
- package/dist/src/server/team-authz.d.ts +13 -0
- package/dist/src/server/team-authz.js +53 -0
- package/dist/src/server/team-autostaff.d.ts +16 -0
- package/dist/src/server/team-autostaff.js +16 -0
- package/dist/src/server/team-list-enrichment.d.ts +22 -0
- package/dist/src/server/team-list-enrichment.js +40 -0
- package/dist/src/server/team-list-serializer.d.ts +2 -0
- package/dist/src/server/team-list-serializer.js +11 -0
- package/dist/src/server/team-memory-digest.d.ts +52 -0
- package/dist/src/server/team-memory-digest.js +200 -0
- package/dist/src/server/team-memory-dream-applier.d.ts +5 -0
- package/dist/src/server/team-memory-dream-applier.js +234 -0
- package/dist/src/server/team-memory-dream-http-serializers.d.ts +13 -0
- package/dist/src/server/team-memory-dream-http-serializers.js +12 -0
- package/dist/src/server/team-memory-dream-ops.d.ts +40 -0
- package/dist/src/server/team-memory-dream-ops.js +153 -0
- package/dist/src/server/team-memory-dream-reverter.d.ts +22 -0
- package/dist/src/server/team-memory-dream-reverter.js +221 -0
- package/dist/src/server/team-memory-dream-run-store.d.ts +23 -0
- package/dist/src/server/team-memory-dream-run-store.js +211 -0
- package/dist/src/server/team-memory-dream-runner.d.ts +37 -0
- package/dist/src/server/team-memory-dream-runner.js +178 -0
- package/dist/src/server/team-memory-dream-scheduler.d.ts +32 -0
- package/dist/src/server/team-memory-dream-scheduler.js +115 -0
- package/dist/src/server/team-memory-dream-store.d.ts +19 -0
- package/dist/src/server/team-memory-dream-store.js +16 -0
- package/dist/src/server/team-memory-dream-types.d.ts +104 -0
- package/dist/src/server/team-memory-dream-types.js +23 -0
- package/dist/src/server/team-memory-export.d.ts +22 -0
- package/dist/src/server/team-memory-export.js +220 -0
- package/dist/src/server/team-memory-feature.d.ts +12 -0
- package/dist/src/server/team-memory-feature.js +12 -0
- package/dist/src/server/team-memory-http-serializers.d.ts +102 -0
- package/dist/src/server/team-memory-http-serializers.js +46 -0
- package/dist/src/server/team-memory-injection.d.ts +31 -0
- package/dist/src/server/team-memory-injection.js +49 -0
- package/dist/src/server/team-memory-store.d.ts +116 -0
- package/dist/src/server/team-memory-store.js +513 -0
- package/dist/src/server/team-operations.d.ts +102 -0
- package/dist/src/server/team-operations.js +387 -0
- package/dist/src/server/team-recall-store.d.ts +38 -0
- package/dist/src/server/team-recall-store.js +205 -0
- package/dist/src/server/terminal-flow-control.d.ts +19 -0
- package/dist/src/server/terminal-flow-control.js +116 -0
- package/dist/src/server/terminal-input-profile.d.ts +10 -0
- package/dist/src/server/terminal-input-profile.js +9 -0
- package/dist/src/server/terminal-protocol.d.ts +29 -0
- package/dist/src/server/terminal-protocol.js +47 -0
- package/dist/src/server/terminal-state-mirror.d.ts +21 -0
- package/dist/src/server/terminal-state-mirror.js +67 -0
- package/dist/src/server/terminal-stream-hub.d.ts +9 -0
- package/dist/src/server/terminal-stream-hub.js +192 -0
- package/dist/src/server/terminal-ws-server.d.ts +6 -0
- package/dist/src/server/terminal-ws-server.js +115 -0
- package/dist/src/server/ui-auth-helpers.d.ts +4 -0
- package/dist/src/server/ui-auth-helpers.js +28 -0
- package/dist/src/server/ui-auth.d.ts +8 -0
- package/dist/src/server/ui-auth.js +32 -0
- package/dist/src/server/version-service.d.ts +16 -0
- package/dist/src/server/version-service.js +72 -0
- package/dist/src/server/webhook-notifier.d.ts +34 -0
- package/dist/src/server/webhook-notifier.js +47 -0
- package/dist/src/server/websocket-upgrade-safety.d.ts +10 -0
- package/dist/src/server/websocket-upgrade-safety.js +35 -0
- package/dist/src/server/windows-command-line.d.ts +3 -0
- package/dist/src/server/windows-command-line.js +9 -0
- package/dist/src/server/windows-filename.d.ts +2 -0
- package/dist/src/server/windows-filename.js +33 -0
- package/dist/src/server/worker-output-tracker.d.ts +14 -0
- package/dist/src/server/worker-output-tracker.js +50 -0
- package/dist/src/server/workflow-cli-policy.d.ts +60 -0
- package/dist/src/server/workflow-cli-policy.js +110 -0
- package/dist/src/server/workflow-dispatch-awaiter.d.ts +12 -0
- package/dist/src/server/workflow-dispatch-awaiter.js +80 -0
- package/dist/src/server/workflow-feature.d.ts +15 -0
- package/dist/src/server/workflow-feature.js +15 -0
- package/dist/src/server/workflow-http-serializers.d.ts +64 -0
- package/dist/src/server/workflow-http-serializers.js +58 -0
- package/dist/src/server/workflow-output-schema.d.ts +18 -0
- package/dist/src/server/workflow-output-schema.js +41 -0
- package/dist/src/server/workflow-run-log-store.d.ts +19 -0
- package/dist/src/server/workflow-run-log-store.js +45 -0
- package/dist/src/server/workflow-run-store.d.ts +50 -0
- package/dist/src/server/workflow-run-store.js +103 -0
- package/dist/src/server/workflow-runner.d.ts +147 -0
- package/dist/src/server/workflow-runner.js +411 -0
- package/dist/src/server/workflow-schedule-create.d.ts +14 -0
- package/dist/src/server/workflow-schedule-create.js +41 -0
- package/dist/src/server/workflow-schedule-store.d.ts +43 -0
- package/dist/src/server/workflow-schedule-store.js +112 -0
- package/dist/src/server/workflow-scheduler.d.ts +36 -0
- package/dist/src/server/workflow-scheduler.js +97 -0
- package/dist/src/server/workflow-script-loader.d.ts +34 -0
- package/dist/src/server/workflow-script-loader.js +106 -0
- package/dist/src/server/workspace-path-validation.d.ts +1 -0
- package/dist/src/server/workspace-path-validation.js +42 -0
- package/dist/src/server/workspace-shell-runtime.d.ts +35 -0
- package/dist/src/server/workspace-shell-runtime.js +228 -0
- package/dist/src/server/workspace-store-contract.d.ts +32 -0
- package/dist/src/server/workspace-store-contract.js +1 -0
- package/dist/src/server/workspace-store-hydration.d.ts +5 -0
- package/dist/src/server/workspace-store-hydration.js +76 -0
- package/dist/src/server/workspace-store-mutations.d.ts +14 -0
- package/dist/src/server/workspace-store-mutations.js +48 -0
- package/dist/src/server/workspace-store-support.d.ts +33 -0
- package/dist/src/server/workspace-store-support.js +36 -0
- package/dist/src/server/workspace-store.d.ts +5 -0
- package/dist/src/server/workspace-store.js +153 -0
- package/dist/src/shared/fs-browse.d.ts +1 -0
- package/dist/src/shared/fs-browse.js +1 -0
- package/dist/src/shared/open-targets.d.ts +20 -0
- package/dist/src/shared/open-targets.js +36 -0
- package/dist/src/shared/path-input.d.ts +12 -0
- package/dist/src/shared/path-input.js +22 -0
- package/dist/src/shared/remote-bridge-routing.d.ts +19 -0
- package/dist/src/shared/remote-bridge-routing.js +141 -0
- package/dist/src/shared/remote-crypto.d.ts +138 -0
- package/dist/src/shared/remote-crypto.js +427 -0
- package/dist/src/shared/remote-pairing-code.d.ts +7 -0
- package/dist/src/shared/remote-pairing-code.js +47 -0
- package/dist/src/shared/remote-protocol.d.ts +160 -0
- package/dist/src/shared/remote-protocol.js +526 -0
- package/dist/src/shared/team-memory.d.ts +11 -0
- package/dist/src/shared/team-memory.js +10 -0
- package/dist/src/shared/team-recall.d.ts +1 -0
- package/dist/src/shared/team-recall.js +1 -0
- package/dist/src/shared/types.d.ts +66 -0
- package/dist/src/shared/types.js +1 -0
- package/dist/vendor/marketplace/en/LICENSE +21 -0
- package/dist/vendor/marketplace/en/SOURCES.md +12 -0
- package/dist/vendor/marketplace/en/academic/academic-anthropologist.md +125 -0
- package/dist/vendor/marketplace/en/academic/academic-geographer.md +127 -0
- package/dist/vendor/marketplace/en/academic/academic-historian.md +123 -0
- package/dist/vendor/marketplace/en/academic/academic-narratologist.md +118 -0
- package/dist/vendor/marketplace/en/academic/academic-psychologist.md +118 -0
- package/dist/vendor/marketplace/en/design/design-brand-guardian.md +322 -0
- package/dist/vendor/marketplace/en/design/design-image-prompt-engineer.md +236 -0
- package/dist/vendor/marketplace/en/design/design-inclusive-visuals-specialist.md +71 -0
- package/dist/vendor/marketplace/en/design/design-ui-designer.md +383 -0
- package/dist/vendor/marketplace/en/design/design-ux-architect.md +469 -0
- package/dist/vendor/marketplace/en/design/design-ux-researcher.md +329 -0
- package/dist/vendor/marketplace/en/design/design-visual-storyteller.md +149 -0
- package/dist/vendor/marketplace/en/design/design-whimsy-injector.md +438 -0
- package/dist/vendor/marketplace/en/engineering/engineering-ai-data-remediation-engineer.md +211 -0
- package/dist/vendor/marketplace/en/engineering/engineering-ai-engineer.md +146 -0
- package/dist/vendor/marketplace/en/engineering/engineering-autonomous-optimization-architect.md +107 -0
- package/dist/vendor/marketplace/en/engineering/engineering-backend-architect.md +235 -0
- package/dist/vendor/marketplace/en/engineering/engineering-cms-developer.md +536 -0
- package/dist/vendor/marketplace/en/engineering/engineering-code-reviewer.md +76 -0
- package/dist/vendor/marketplace/en/engineering/engineering-codebase-onboarding-engineer.md +173 -0
- package/dist/vendor/marketplace/en/engineering/engineering-data-engineer.md +306 -0
- package/dist/vendor/marketplace/en/engineering/engineering-database-optimizer.md +176 -0
- package/dist/vendor/marketplace/en/engineering/engineering-devops-automator.md +376 -0
- package/dist/vendor/marketplace/en/engineering/engineering-email-intelligence-engineer.md +353 -0
- package/dist/vendor/marketplace/en/engineering/engineering-embedded-firmware-engineer.md +173 -0
- package/dist/vendor/marketplace/en/engineering/engineering-feishu-integration-developer.md +598 -0
- package/dist/vendor/marketplace/en/engineering/engineering-filament-optimization-specialist.md +283 -0
- package/dist/vendor/marketplace/en/engineering/engineering-frontend-developer.md +225 -0
- package/dist/vendor/marketplace/en/engineering/engineering-git-workflow-master.md +84 -0
- package/dist/vendor/marketplace/en/engineering/engineering-incident-response-commander.md +444 -0
- package/dist/vendor/marketplace/en/engineering/engineering-minimal-change-engineer.md +207 -0
- package/dist/vendor/marketplace/en/engineering/engineering-mobile-app-builder.md +493 -0
- package/dist/vendor/marketplace/en/engineering/engineering-rapid-prototyper.md +462 -0
- package/dist/vendor/marketplace/en/engineering/engineering-security-engineer.md +304 -0
- package/dist/vendor/marketplace/en/engineering/engineering-senior-developer.md +176 -0
- package/dist/vendor/marketplace/en/engineering/engineering-software-architect.md +81 -0
- package/dist/vendor/marketplace/en/engineering/engineering-solidity-smart-contract-engineer.md +522 -0
- package/dist/vendor/marketplace/en/engineering/engineering-sre.md +90 -0
- package/dist/vendor/marketplace/en/engineering/engineering-technical-writer.md +393 -0
- package/dist/vendor/marketplace/en/engineering/engineering-threat-detection-engineer.md +534 -0
- package/dist/vendor/marketplace/en/engineering/engineering-voice-ai-integration-engineer.md +561 -0
- package/dist/vendor/marketplace/en/engineering/engineering-wechat-mini-program-developer.md +350 -0
- package/dist/vendor/marketplace/en/finance/finance-bookkeeper-controller.md +260 -0
- package/dist/vendor/marketplace/en/finance/finance-financial-analyst.md +234 -0
- package/dist/vendor/marketplace/en/finance/finance-fpa-analyst.md +263 -0
- package/dist/vendor/marketplace/en/finance/finance-investment-researcher.md +272 -0
- package/dist/vendor/marketplace/en/finance/finance-tax-strategist.md +239 -0
- package/dist/vendor/marketplace/en/game-development/blender/blender-addon-engineer.md +234 -0
- package/dist/vendor/marketplace/en/game-development/game-audio-engineer.md +264 -0
- package/dist/vendor/marketplace/en/game-development/game-designer.md +167 -0
- package/dist/vendor/marketplace/en/game-development/godot/godot-gameplay-scripter.md +334 -0
- package/dist/vendor/marketplace/en/game-development/godot/godot-multiplayer-engineer.md +297 -0
- package/dist/vendor/marketplace/en/game-development/godot/godot-shader-developer.md +266 -0
- package/dist/vendor/marketplace/en/game-development/level-designer.md +208 -0
- package/dist/vendor/marketplace/en/game-development/narrative-designer.md +243 -0
- package/dist/vendor/marketplace/en/game-development/roblox-studio/roblox-avatar-creator.md +297 -0
- package/dist/vendor/marketplace/en/game-development/roblox-studio/roblox-experience-designer.md +305 -0
- package/dist/vendor/marketplace/en/game-development/roblox-studio/roblox-systems-scripter.md +325 -0
- package/dist/vendor/marketplace/en/game-development/technical-artist.md +229 -0
- package/dist/vendor/marketplace/en/game-development/unity/unity-architect.md +271 -0
- package/dist/vendor/marketplace/en/game-development/unity/unity-editor-tool-developer.md +310 -0
- package/dist/vendor/marketplace/en/game-development/unity/unity-multiplayer-engineer.md +321 -0
- package/dist/vendor/marketplace/en/game-development/unity/unity-shader-graph-artist.md +269 -0
- package/dist/vendor/marketplace/en/game-development/unreal-engine/unreal-multiplayer-architect.md +313 -0
- package/dist/vendor/marketplace/en/game-development/unreal-engine/unreal-systems-engineer.md +310 -0
- package/dist/vendor/marketplace/en/game-development/unreal-engine/unreal-technical-artist.md +256 -0
- package/dist/vendor/marketplace/en/game-development/unreal-engine/unreal-world-builder.md +273 -0
- package/dist/vendor/marketplace/en/integrations/mcp-memory/backend-architect-with-memory.md +247 -0
- package/dist/vendor/marketplace/en/manifest.json +1869 -0
- package/dist/vendor/marketplace/en/marketing/marketing-agentic-search-optimizer.md +311 -0
- package/dist/vendor/marketplace/en/marketing/marketing-ai-citation-strategist.md +170 -0
- package/dist/vendor/marketplace/en/marketing/marketing-app-store-optimizer.md +321 -0
- package/dist/vendor/marketplace/en/marketing/marketing-baidu-seo-specialist.md +226 -0
- package/dist/vendor/marketplace/en/marketing/marketing-bilibili-content-strategist.md +199 -0
- package/dist/vendor/marketplace/en/marketing/marketing-book-co-author.md +110 -0
- package/dist/vendor/marketplace/en/marketing/marketing-carousel-growth-engine.md +199 -0
- package/dist/vendor/marketplace/en/marketing/marketing-china-ecommerce-operator.md +283 -0
- package/dist/vendor/marketplace/en/marketing/marketing-china-market-localization-strategist.md +283 -0
- package/dist/vendor/marketplace/en/marketing/marketing-content-creator.md +54 -0
- package/dist/vendor/marketplace/en/marketing/marketing-cross-border-ecommerce.md +259 -0
- package/dist/vendor/marketplace/en/marketing/marketing-douyin-strategist.md +149 -0
- package/dist/vendor/marketplace/en/marketing/marketing-growth-hacker.md +54 -0
- package/dist/vendor/marketplace/en/marketing/marketing-instagram-curator.md +113 -0
- package/dist/vendor/marketplace/en/marketing/marketing-kuaishou-strategist.md +223 -0
- package/dist/vendor/marketplace/en/marketing/marketing-linkedin-content-creator.md +214 -0
- package/dist/vendor/marketplace/en/marketing/marketing-livestream-commerce-coach.md +305 -0
- package/dist/vendor/marketplace/en/marketing/marketing-podcast-strategist.md +277 -0
- package/dist/vendor/marketplace/en/marketing/marketing-private-domain-operator.md +308 -0
- package/dist/vendor/marketplace/en/marketing/marketing-reddit-community-builder.md +123 -0
- package/dist/vendor/marketplace/en/marketing/marketing-seo-specialist.md +321 -0
- package/dist/vendor/marketplace/en/marketing/marketing-short-video-editing-coach.md +412 -0
- package/dist/vendor/marketplace/en/marketing/marketing-social-media-strategist.md +125 -0
- package/dist/vendor/marketplace/en/marketing/marketing-tiktok-strategist.md +125 -0
- package/dist/vendor/marketplace/en/marketing/marketing-twitter-engager.md +126 -0
- package/dist/vendor/marketplace/en/marketing/marketing-video-optimization-specialist.md +119 -0
- package/dist/vendor/marketplace/en/marketing/marketing-wechat-official-account.md +145 -0
- package/dist/vendor/marketplace/en/marketing/marketing-weibo-strategist.md +240 -0
- package/dist/vendor/marketplace/en/marketing/marketing-xiaohongshu-specialist.md +138 -0
- package/dist/vendor/marketplace/en/marketing/marketing-zhihu-strategist.md +162 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-auditor.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-creative-strategist.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-paid-social-strategist.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-ppc-strategist.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-programmatic-buyer.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-search-query-analyst.md +71 -0
- package/dist/vendor/marketplace/en/paid-media/paid-media-tracking-specialist.md +71 -0
- package/dist/vendor/marketplace/en/product/product-behavioral-nudge-engine.md +80 -0
- package/dist/vendor/marketplace/en/product/product-feedback-synthesizer.md +119 -0
- package/dist/vendor/marketplace/en/product/product-manager.md +469 -0
- package/dist/vendor/marketplace/en/product/product-sprint-prioritizer.md +154 -0
- package/dist/vendor/marketplace/en/product/product-trend-researcher.md +159 -0
- package/dist/vendor/marketplace/en/project-management/project-management-experiment-tracker.md +198 -0
- package/dist/vendor/marketplace/en/project-management/project-management-jira-workflow-steward.md +230 -0
- package/dist/vendor/marketplace/en/project-management/project-management-project-shepherd.md +194 -0
- package/dist/vendor/marketplace/en/project-management/project-management-studio-operations.md +200 -0
- package/dist/vendor/marketplace/en/project-management/project-management-studio-producer.md +203 -0
- package/dist/vendor/marketplace/en/project-management/project-manager-senior.md +135 -0
- package/dist/vendor/marketplace/en/sales/sales-account-strategist.md +227 -0
- package/dist/vendor/marketplace/en/sales/sales-coach.md +271 -0
- package/dist/vendor/marketplace/en/sales/sales-deal-strategist.md +180 -0
- package/dist/vendor/marketplace/en/sales/sales-discovery-coach.md +225 -0
- package/dist/vendor/marketplace/en/sales/sales-engineer.md +182 -0
- package/dist/vendor/marketplace/en/sales/sales-outbound-strategist.md +201 -0
- package/dist/vendor/marketplace/en/sales/sales-pipeline-analyst.md +267 -0
- package/dist/vendor/marketplace/en/sales/sales-proposal-strategist.md +217 -0
- package/dist/vendor/marketplace/en/spatial-computing/macos-spatial-metal-engineer.md +337 -0
- package/dist/vendor/marketplace/en/spatial-computing/terminal-integration-specialist.md +70 -0
- package/dist/vendor/marketplace/en/spatial-computing/visionos-spatial-engineer.md +54 -0
- package/dist/vendor/marketplace/en/spatial-computing/xr-cockpit-interaction-specialist.md +32 -0
- package/dist/vendor/marketplace/en/spatial-computing/xr-immersive-developer.md +32 -0
- package/dist/vendor/marketplace/en/spatial-computing/xr-interface-architect.md +32 -0
- package/dist/vendor/marketplace/en/specialized/accounts-payable-agent.md +185 -0
- package/dist/vendor/marketplace/en/specialized/agentic-identity-trust.md +387 -0
- package/dist/vendor/marketplace/en/specialized/agents-orchestrator.md +367 -0
- package/dist/vendor/marketplace/en/specialized/automation-governance-architect.md +216 -0
- package/dist/vendor/marketplace/en/specialized/blockchain-security-auditor.md +463 -0
- package/dist/vendor/marketplace/en/specialized/compliance-auditor.md +158 -0
- package/dist/vendor/marketplace/en/specialized/corporate-training-designer.md +192 -0
- package/dist/vendor/marketplace/en/specialized/customer-service.md +398 -0
- package/dist/vendor/marketplace/en/specialized/data-consolidation-agent.md +60 -0
- package/dist/vendor/marketplace/en/specialized/government-digital-presales-consultant.md +363 -0
- package/dist/vendor/marketplace/en/specialized/healthcare-customer-service.md +389 -0
- package/dist/vendor/marketplace/en/specialized/healthcare-marketing-compliance.md +395 -0
- package/dist/vendor/marketplace/en/specialized/hospitality-guest-services.md +603 -0
- package/dist/vendor/marketplace/en/specialized/hr-onboarding.md +451 -0
- package/dist/vendor/marketplace/en/specialized/identity-graph-operator.md +260 -0
- package/dist/vendor/marketplace/en/specialized/language-translator.md +264 -0
- package/dist/vendor/marketplace/en/specialized/legal-billing-time-tracking.md +569 -0
- package/dist/vendor/marketplace/en/specialized/legal-client-intake.md +492 -0
- package/dist/vendor/marketplace/en/specialized/legal-document-review.md +454 -0
- package/dist/vendor/marketplace/en/specialized/loan-officer-assistant.md +555 -0
- package/dist/vendor/marketplace/en/specialized/lsp-index-engineer.md +314 -0
- package/dist/vendor/marketplace/en/specialized/real-estate-buyer-seller.md +596 -0
- package/dist/vendor/marketplace/en/specialized/recruitment-specialist.md +509 -0
- package/dist/vendor/marketplace/en/specialized/report-distribution-agent.md +65 -0
- package/dist/vendor/marketplace/en/specialized/retail-customer-returns.md +566 -0
- package/dist/vendor/marketplace/en/specialized/sales-data-extraction-agent.md +67 -0
- package/dist/vendor/marketplace/en/specialized/sales-outreach.md +425 -0
- package/dist/vendor/marketplace/en/specialized/specialized-chief-of-staff.md +279 -0
- package/dist/vendor/marketplace/en/specialized/specialized-civil-engineer.md +356 -0
- package/dist/vendor/marketplace/en/specialized/specialized-cultural-intelligence-strategist.md +88 -0
- package/dist/vendor/marketplace/en/specialized/specialized-developer-advocate.md +317 -0
- package/dist/vendor/marketplace/en/specialized/specialized-document-generator.md +55 -0
- package/dist/vendor/marketplace/en/specialized/specialized-french-consulting-market.md +192 -0
- package/dist/vendor/marketplace/en/specialized/specialized-korean-business-navigator.md +216 -0
- package/dist/vendor/marketplace/en/specialized/specialized-mcp-builder.md +248 -0
- package/dist/vendor/marketplace/en/specialized/specialized-model-qa.md +488 -0
- package/dist/vendor/marketplace/en/specialized/specialized-salesforce-architect.md +180 -0
- package/dist/vendor/marketplace/en/specialized/specialized-workflow-architect.md +597 -0
- package/dist/vendor/marketplace/en/specialized/study-abroad-advisor.md +282 -0
- package/dist/vendor/marketplace/en/specialized/supply-chain-strategist.md +582 -0
- package/dist/vendor/marketplace/en/support/support-analytics-reporter.md +365 -0
- package/dist/vendor/marketplace/en/support/support-executive-summary-generator.md +212 -0
- package/dist/vendor/marketplace/en/support/support-finance-tracker.md +442 -0
- package/dist/vendor/marketplace/en/support/support-infrastructure-maintainer.md +618 -0
- package/dist/vendor/marketplace/en/support/support-legal-compliance-checker.md +588 -0
- package/dist/vendor/marketplace/en/support/support-support-responder.md +585 -0
- package/dist/vendor/marketplace/en/testing/testing-accessibility-auditor.md +316 -0
- package/dist/vendor/marketplace/en/testing/testing-api-tester.md +306 -0
- package/dist/vendor/marketplace/en/testing/testing-evidence-collector.md +210 -0
- package/dist/vendor/marketplace/en/testing/testing-performance-benchmarker.md +268 -0
- package/dist/vendor/marketplace/en/testing/testing-reality-checker.md +236 -0
- package/dist/vendor/marketplace/en/testing/testing-test-results-analyzer.md +305 -0
- package/dist/vendor/marketplace/en/testing/testing-tool-evaluator.md +394 -0
- package/dist/vendor/marketplace/en/testing/testing-workflow-optimizer.md +450 -0
- package/dist/vendor/marketplace/zh/LICENSE +22 -0
- package/dist/vendor/marketplace/zh/SOURCES.md +12 -0
- package/dist/vendor/marketplace/zh/academic/academic-anthropologist.md +124 -0
- package/dist/vendor/marketplace/zh/academic/academic-geographer.md +126 -0
- package/dist/vendor/marketplace/zh/academic/academic-historian.md +122 -0
- package/dist/vendor/marketplace/zh/academic/academic-narratologist.md +117 -0
- package/dist/vendor/marketplace/zh/academic/academic-psychologist.md +117 -0
- package/dist/vendor/marketplace/zh/academic/academic-study-planner.md +214 -0
- package/dist/vendor/marketplace/zh/design/design-brand-guardian.md +321 -0
- package/dist/vendor/marketplace/zh/design/design-image-prompt-engineer.md +255 -0
- package/dist/vendor/marketplace/zh/design/design-inclusive-visuals-specialist.md +177 -0
- package/dist/vendor/marketplace/zh/design/design-ui-designer.md +382 -0
- package/dist/vendor/marketplace/zh/design/design-ux-architect.md +482 -0
- package/dist/vendor/marketplace/zh/design/design-ux-researcher.md +328 -0
- package/dist/vendor/marketplace/zh/design/design-visual-storyteller.md +159 -0
- package/dist/vendor/marketplace/zh/design/design-whimsy-injector.md +453 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-ai-data-remediation-engineer.md +209 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-ai-engineer.md +161 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-autonomous-optimization-architect.md +115 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-backend-architect.md +234 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-cms-developer.md +534 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-code-reviewer.md +172 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-codebase-onboarding-engineer.md +172 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-data-engineer.md +324 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-database-optimizer.md +175 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-devops-automator.md +375 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-dingtalk-integration-developer.md +574 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-email-intelligence-engineer.md +349 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-embedded-firmware-engineer.md +168 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-embedded-linux-driver-engineer.md +255 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-feishu-integration-developer.md +597 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-filament-optimization-specialist.md +283 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-fpga-digital-design-engineer.md +227 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-frontend-developer.md +224 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-git-workflow-master.md +220 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-incident-response-commander.md +465 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-iot-solution-architect.md +220 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-mechanical-design-engineer.md +311 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-minimal-change-engineer.md +206 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-mobile-app-builder.md +434 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-pc-host-engineer.md +231 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-rapid-prototyper.md +461 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-security-engineer.md +303 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-senior-developer.md +177 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-software-architect.md +200 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-solidity-smart-contract-engineer.md +541 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-sre.md +233 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-technical-writer.md +409 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-threat-detection-engineer.md +553 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-voice-ai-integration-engineer.md +560 -0
- package/dist/vendor/marketplace/zh/engineering/engineering-wechat-mini-program-developer.md +288 -0
- package/dist/vendor/marketplace/zh/finance/finance-bookkeeper-controller.md +271 -0
- package/dist/vendor/marketplace/zh/finance/finance-financial-analyst.md +244 -0
- package/dist/vendor/marketplace/zh/finance/finance-financial-forecaster.md +213 -0
- package/dist/vendor/marketplace/zh/finance/finance-fpa-analyst.md +272 -0
- package/dist/vendor/marketplace/zh/finance/finance-fraud-detector.md +241 -0
- package/dist/vendor/marketplace/zh/finance/finance-investment-researcher.md +283 -0
- package/dist/vendor/marketplace/zh/finance/finance-invoice-manager.md +242 -0
- package/dist/vendor/marketplace/zh/finance/finance-tax-strategist.md +250 -0
- package/dist/vendor/marketplace/zh/game-development/blender/blender-addon-engineer.md +233 -0
- package/dist/vendor/marketplace/zh/game-development/game-audio-engineer.md +265 -0
- package/dist/vendor/marketplace/zh/game-development/game-designer.md +168 -0
- package/dist/vendor/marketplace/zh/game-development/godot/godot-gameplay-scripter.md +335 -0
- package/dist/vendor/marketplace/zh/game-development/godot/godot-multiplayer-engineer.md +296 -0
- package/dist/vendor/marketplace/zh/game-development/godot/godot-shader-developer.md +267 -0
- package/dist/vendor/marketplace/zh/game-development/level-designer.md +209 -0
- package/dist/vendor/marketplace/zh/game-development/narrative-designer.md +244 -0
- package/dist/vendor/marketplace/zh/game-development/roblox-studio/roblox-avatar-creator.md +298 -0
- package/dist/vendor/marketplace/zh/game-development/roblox-studio/roblox-experience-designer.md +306 -0
- package/dist/vendor/marketplace/zh/game-development/roblox-studio/roblox-systems-scripter.md +325 -0
- package/dist/vendor/marketplace/zh/game-development/technical-artist.md +230 -0
- package/dist/vendor/marketplace/zh/game-development/unity/unity-architect.md +272 -0
- package/dist/vendor/marketplace/zh/game-development/unity/unity-editor-tool-developer.md +300 -0
- package/dist/vendor/marketplace/zh/game-development/unity/unity-multiplayer-engineer.md +238 -0
- package/dist/vendor/marketplace/zh/game-development/unity/unity-shader-graph-artist.md +270 -0
- package/dist/vendor/marketplace/zh/game-development/unreal-engine/unreal-multiplayer-architect.md +314 -0
- package/dist/vendor/marketplace/zh/game-development/unreal-engine/unreal-systems-engineer.md +311 -0
- package/dist/vendor/marketplace/zh/game-development/unreal-engine/unreal-technical-artist.md +256 -0
- package/dist/vendor/marketplace/zh/game-development/unreal-engine/unreal-world-builder.md +274 -0
- package/dist/vendor/marketplace/zh/hr/hr-performance-reviewer.md +248 -0
- package/dist/vendor/marketplace/zh/hr/hr-recruiter.md +232 -0
- package/dist/vendor/marketplace/zh/legal/legal-contract-reviewer.md +240 -0
- package/dist/vendor/marketplace/zh/legal/legal-policy-writer.md +308 -0
- package/dist/vendor/marketplace/zh/manifest.json +2181 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-agentic-search-optimizer.md +312 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-ai-citation-strategist.md +169 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-app-store-optimizer.md +319 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-baidu-seo-specialist.md +220 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-bilibili-strategist.md +194 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-book-co-author.md +109 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-carousel-growth-engine.md +215 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-china-ecommerce-operator.md +277 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-china-market-localization-strategist.md +282 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-content-creator.md +145 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-cross-border-ecommerce.md +260 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-daily-news-briefing.md +303 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-douyin-strategist.md +150 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-ecommerce-operator.md +216 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-growth-hacker.md +121 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-instagram-curator.md +179 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-knowledge-commerce-strategist.md +384 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-kuaishou-strategist.md +182 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-linkedin-content-creator.md +232 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-livestream-commerce-coach.md +303 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-podcast-strategist.md +278 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-private-domain-operator.md +309 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-reddit-community-builder.md +127 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-seo-specialist.md +298 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-short-video-editing-coach.md +413 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-social-media-strategist.md +118 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-tiktok-strategist.md +124 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-twitter-engager.md +132 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-video-optimization-specialist.md +128 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-wechat-official-account.md +158 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-wechat-operator.md +156 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-weibo-strategist.md +241 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-weixin-channels-strategist.md +297 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-xiaohongshu-operator.md +139 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-xiaohongshu-specialist.md +151 -0
- package/dist/vendor/marketplace/zh/marketing/marketing-zhihu-strategist.md +175 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-auditor.md +170 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-creative-strategist.md +173 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-paid-social-strategist.md +180 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-ppc-strategist.md +180 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-programmatic-buyer.md +177 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-search-query-analyst.md +182 -0
- package/dist/vendor/marketplace/zh/paid-media/paid-media-tracking-specialist.md +199 -0
- package/dist/vendor/marketplace/zh/product/product-behavioral-nudge-engine.md +246 -0
- package/dist/vendor/marketplace/zh/product/product-feedback-synthesizer.md +175 -0
- package/dist/vendor/marketplace/zh/product/product-manager.md +474 -0
- package/dist/vendor/marketplace/zh/product/product-sprint-prioritizer.md +133 -0
- package/dist/vendor/marketplace/zh/product/product-trend-researcher.md +143 -0
- package/dist/vendor/marketplace/zh/project-management/project-management-experiment-tracker.md +206 -0
- package/dist/vendor/marketplace/zh/project-management/project-management-jira-workflow-steward.md +249 -0
- package/dist/vendor/marketplace/zh/project-management/project-management-project-shepherd.md +202 -0
- package/dist/vendor/marketplace/zh/project-management/project-management-studio-operations.md +208 -0
- package/dist/vendor/marketplace/zh/project-management/project-management-studio-producer.md +211 -0
- package/dist/vendor/marketplace/zh/project-management/project-manager-senior.md +135 -0
- package/dist/vendor/marketplace/zh/sales/sales-account-strategist.md +243 -0
- package/dist/vendor/marketplace/zh/sales/sales-coach.md +291 -0
- package/dist/vendor/marketplace/zh/sales/sales-deal-strategist.md +204 -0
- package/dist/vendor/marketplace/zh/sales/sales-discovery-coach.md +230 -0
- package/dist/vendor/marketplace/zh/sales/sales-engineer.md +200 -0
- package/dist/vendor/marketplace/zh/sales/sales-outbound-strategist.md +208 -0
- package/dist/vendor/marketplace/zh/sales/sales-pipeline-analyst.md +284 -0
- package/dist/vendor/marketplace/zh/sales/sales-proposal-strategist.md +233 -0
- package/dist/vendor/marketplace/zh/spatial-computing/macos-spatial-metal-engineer.md +337 -0
- package/dist/vendor/marketplace/zh/spatial-computing/terminal-integration-specialist.md +236 -0
- package/dist/vendor/marketplace/zh/spatial-computing/visionos-spatial-engineer.md +282 -0
- package/dist/vendor/marketplace/zh/spatial-computing/xr-cockpit-interaction-specialist.md +220 -0
- package/dist/vendor/marketplace/zh/spatial-computing/xr-immersive-developer.md +229 -0
- package/dist/vendor/marketplace/zh/spatial-computing/xr-interface-architect.md +253 -0
- package/dist/vendor/marketplace/zh/specialized/accounts-payable-agent.md +212 -0
- package/dist/vendor/marketplace/zh/specialized/agentic-identity-trust.md +388 -0
- package/dist/vendor/marketplace/zh/specialized/agents-orchestrator.md +366 -0
- package/dist/vendor/marketplace/zh/specialized/automation-governance-architect.md +215 -0
- package/dist/vendor/marketplace/zh/specialized/blockchain-security-auditor.md +484 -0
- package/dist/vendor/marketplace/zh/specialized/compliance-auditor.md +172 -0
- package/dist/vendor/marketplace/zh/specialized/corporate-training-designer.md +191 -0
- package/dist/vendor/marketplace/zh/specialized/data-consolidation-agent.md +327 -0
- package/dist/vendor/marketplace/zh/specialized/gaokao-college-advisor.md +333 -0
- package/dist/vendor/marketplace/zh/specialized/government-digital-presales-consultant.md +362 -0
- package/dist/vendor/marketplace/zh/specialized/healthcare-customer-service.md +388 -0
- package/dist/vendor/marketplace/zh/specialized/healthcare-marketing-compliance.md +394 -0
- package/dist/vendor/marketplace/zh/specialized/hospitality-guest-services.md +597 -0
- package/dist/vendor/marketplace/zh/specialized/hr-onboarding.md +450 -0
- package/dist/vendor/marketplace/zh/specialized/identity-graph-operator.md +270 -0
- package/dist/vendor/marketplace/zh/specialized/language-translator.md +275 -0
- package/dist/vendor/marketplace/zh/specialized/legal-billing-time-tracking.md +566 -0
- package/dist/vendor/marketplace/zh/specialized/legal-client-intake.md +487 -0
- package/dist/vendor/marketplace/zh/specialized/legal-document-review.md +452 -0
- package/dist/vendor/marketplace/zh/specialized/livestock-archive-auditor.md +135 -0
- package/dist/vendor/marketplace/zh/specialized/loan-officer-assistant.md +549 -0
- package/dist/vendor/marketplace/zh/specialized/lsp-index-engineer.md +334 -0
- package/dist/vendor/marketplace/zh/specialized/prompt-engineer.md +176 -0
- package/dist/vendor/marketplace/zh/specialized/real-estate-buyer-seller.md +594 -0
- package/dist/vendor/marketplace/zh/specialized/recruitment-specialist.md +508 -0
- package/dist/vendor/marketplace/zh/specialized/report-distribution-agent.md +354 -0
- package/dist/vendor/marketplace/zh/specialized/retail-customer-returns.md +564 -0
- package/dist/vendor/marketplace/zh/specialized/sales-data-extraction-agent.md +159 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-ai-policy-writer.md +217 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-chief-of-staff.md +278 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-civil-engineer.md +355 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-cultural-intelligence-strategist.md +168 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-developer-advocate.md +334 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-document-generator.md +346 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-french-consulting-market.md +191 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-korean-business-navigator.md +215 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-mcp-builder.md +351 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-meeting-assistant.md +236 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-model-qa.md +507 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-pricing-optimizer.md +254 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-risk-assessor.md +240 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-salesforce-architect.md +179 -0
- package/dist/vendor/marketplace/zh/specialized/specialized-workflow-architect.md +596 -0
- package/dist/vendor/marketplace/zh/specialized/study-abroad-advisor.md +281 -0
- package/dist/vendor/marketplace/zh/specialized/technical-translator-agent.md +167 -0
- package/dist/vendor/marketplace/zh/specialized/zk-steward.md +228 -0
- package/dist/vendor/marketplace/zh/supply-chain/supply-chain-inventory-forecaster.md +212 -0
- package/dist/vendor/marketplace/zh/supply-chain/supply-chain-route-optimizer.md +224 -0
- package/dist/vendor/marketplace/zh/supply-chain/supply-chain-strategist.md +581 -0
- package/dist/vendor/marketplace/zh/supply-chain/supply-chain-vendor-evaluator.md +232 -0
- package/dist/vendor/marketplace/zh/support/support-analytics-reporter.md +364 -0
- package/dist/vendor/marketplace/zh/support/support-executive-summary-generator.md +217 -0
- package/dist/vendor/marketplace/zh/support/support-finance-tracker.md +447 -0
- package/dist/vendor/marketplace/zh/support/support-infrastructure-maintainer.md +623 -0
- package/dist/vendor/marketplace/zh/support/support-legal-compliance-checker.md +587 -0
- package/dist/vendor/marketplace/zh/support/support-recruitment-specialist.md +508 -0
- package/dist/vendor/marketplace/zh/support/support-support-responder.md +584 -0
- package/dist/vendor/marketplace/zh/testing/testing-accessibility-auditor.md +329 -0
- package/dist/vendor/marketplace/zh/testing/testing-api-tester.md +305 -0
- package/dist/vendor/marketplace/zh/testing/testing-embedded-qa-engineer.md +258 -0
- package/dist/vendor/marketplace/zh/testing/testing-evidence-collector.md +153 -0
- package/dist/vendor/marketplace/zh/testing/testing-performance-benchmarker.md +196 -0
- package/dist/vendor/marketplace/zh/testing/testing-reality-checker.md +235 -0
- package/dist/vendor/marketplace/zh/testing/testing-test-results-analyzer.md +313 -0
- package/dist/vendor/marketplace/zh/testing/testing-tool-evaluator.md +402 -0
- package/dist/vendor/marketplace/zh/testing/testing-workflow-optimizer.md +458 -0
- package/package.json +131 -0
- package/scripts/postinstall-native-artifacts.mjs +113 -0
- package/web/dist/assets/AddWorkerDialog-BU2Fn-Mx.js +2 -0
- package/web/dist/assets/AddWorkspaceFlow-BV04MkRt.js +1 -0
- package/web/dist/assets/FirstRunWizard-DS4IYOrd.js +1 -0
- package/web/dist/assets/MarketplaceDrawer-CIQ2B6Fx.js +76 -0
- package/web/dist/assets/TaskGraphDrawer-BPMcRocd.js +1 -0
- package/web/dist/assets/WhatsNewDialog-DEgVY_LD.js +1 -0
- package/web/dist/assets/WorkerModal-DiCcTPpc.js +1 -0
- package/web/dist/assets/WorkflowsDrawer-M2CgAJWK.js +1 -0
- package/web/dist/assets/WorkspaceMemoryDrawer-ClJIqWck.js +1 -0
- package/web/dist/assets/WorkspaceTaskDrawer-gjvXuZ2K.js +1 -0
- package/web/dist/assets/addon-clipboard-wHJhZAA4.js +1 -0
- package/web/dist/assets/addon-fit-DX4qG4td.js +1 -0
- package/web/dist/assets/addon-unicode11-Bt8F3D7-.js +7 -0
- package/web/dist/assets/addon-web-links-DIbG5aQx.js +1 -0
- package/web/dist/assets/addon-webgl-DCtw1yLn.js +64 -0
- package/web/dist/assets/finder-C4Jmsb0B.png +0 -0
- package/web/dist/assets/ghostty-D-Js4rdm.png +0 -0
- package/web/dist/assets/index-bOMtwrkA.js +73 -0
- package/web/dist/assets/index-i9YgsMdD.css +1 -0
- package/web/dist/assets/path-join-7MR1s7b1.js +1 -0
- package/web/dist/assets/search-CmzeVhy0.js +1 -0
- package/web/dist/assets/xterm-B-qIQCd3.js +16 -0
- package/web/dist/assets/zed-C5BQT8X3.png +0 -0
- package/web/dist/bilibili.ico +0 -0
- package/web/dist/cli-icons/claude.png +0 -0
- package/web/dist/cli-icons/codex.png +0 -0
- package/web/dist/cli-icons/gemini.png +0 -0
- package/web/dist/cli-icons/hermes.png +0 -0
- package/web/dist/cli-icons/opencode.svg +18 -0
- package/web/dist/icons/apple-touch-icon-180.png +0 -0
- package/web/dist/icons/icon-192.png +0 -0
- package/web/dist/icons/icon-32.png +0 -0
- package/web/dist/icons/icon-512-maskable.png +0 -0
- package/web/dist/icons/icon-512.png +0 -0
- package/web/dist/index.html +39 -0
- package/web/dist/logo.png +0 -0
- package/web/dist/manifest.webmanifest +60 -0
- package/web/dist/screenshots/wide-overview.png +0 -0
- package/web/dist/sounds/LICENSE-KENNEY.txt +22 -0
- package/web/dist/sounds/hive-beacon.ogg +0 -0
- package/web/dist/sounds/hive-cascade.ogg +0 -0
- package/web/dist/sounds/hive-chime.ogg +0 -0
- package/web/dist/sounds/hive-ping.ogg +0 -0
- package/web/dist/sounds/hive-resolve.ogg +0 -0
- package/web/dist/sounds/hive-soft.ogg +0 -0
- package/web/dist/sw.js +99 -0
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { createRuntimeStoreDreamMethods } from './runtime-store-dream.js';
|
|
2
|
+
import { createRuntimeStoreLifecycle, createRuntimeStoreServices, logTasksFileWatchStartError, } from './runtime-store-helpers.js';
|
|
3
|
+
import { createRuntimeStoreMemoryMethods } from './runtime-store-memory.js';
|
|
4
|
+
import { createRuntimeStoreRemoteMethods } from './runtime-store-remote.js';
|
|
5
|
+
import { createRuntimeStoreWorkflowRuntime } from './runtime-store-workflows.js';
|
|
6
|
+
import { persistWorkflowSchedule } from './workflow-schedule-create.js';
|
|
7
|
+
export const createRuntimeStore = (options = {}) => {
|
|
8
|
+
const services = createRuntimeStoreServices(options);
|
|
9
|
+
const lifecycle = createRuntimeStoreLifecycle(options.agentManager ? { agentManager: options.agentManager, services } : { services });
|
|
10
|
+
const runDataMutation = (mutation) => {
|
|
11
|
+
if (!services.db) {
|
|
12
|
+
mutation();
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
services.db.transaction(mutation)();
|
|
16
|
+
};
|
|
17
|
+
let workflowRuntime;
|
|
18
|
+
const getWorkflowRuntime = () => {
|
|
19
|
+
if (!workflowRuntime)
|
|
20
|
+
throw new Error('Workflow runtime not initialized');
|
|
21
|
+
return workflowRuntime;
|
|
22
|
+
};
|
|
23
|
+
const store = {
|
|
24
|
+
close: async () => {
|
|
25
|
+
workflowRuntime?.scheduler.close();
|
|
26
|
+
await services.teamMemoryDreamScheduler.close();
|
|
27
|
+
await lifecycle.close();
|
|
28
|
+
},
|
|
29
|
+
createWorkspace: (path, name) => {
|
|
30
|
+
const workspace = services.workspaceStore.createWorkspace(path, name);
|
|
31
|
+
void lifecycle
|
|
32
|
+
.startWorkspaceWatch(workspace.id)
|
|
33
|
+
.catch((error) => logTasksFileWatchStartError(workspace.id, error));
|
|
34
|
+
return workspace;
|
|
35
|
+
},
|
|
36
|
+
listWorkspaces: () => services.workspaceStore.listWorkspaces(),
|
|
37
|
+
deleteWorkspace: async (workspaceId) => {
|
|
38
|
+
const workspace = services.workspaceStore.getWorkspaceSnapshot(workspaceId);
|
|
39
|
+
lifecycle.deleteWorkspaceShell(workspaceId);
|
|
40
|
+
for (const agent of workspace.agents) {
|
|
41
|
+
const activeRun = services.agentRuntime.getActiveRunByAgentId(workspaceId, agent.id);
|
|
42
|
+
if (activeRun)
|
|
43
|
+
services.agentRuntime.stopAgentRun(activeRun.runId);
|
|
44
|
+
services.agentRuntime.deleteAgentLaunchConfig(workspaceId, agent.id);
|
|
45
|
+
}
|
|
46
|
+
await services.tasksFileWatcher.stop(workspaceId);
|
|
47
|
+
services.teamMemoryExport.cancel(workspaceId);
|
|
48
|
+
runDataMutation(() => {
|
|
49
|
+
services.dispatchLedgerStore.deleteWorkspaceDispatches(workspaceId);
|
|
50
|
+
services.teamMemoryStore.deleteWorkspaceMemories(workspaceId);
|
|
51
|
+
services.teamMemoryDreamStore.deleteWorkspaceDreamRuns(workspaceId);
|
|
52
|
+
services.workspaceStore.deleteWorkspace(workspaceId);
|
|
53
|
+
});
|
|
54
|
+
if (services.settings.getAppState('active_workspace_id')?.value === workspaceId) {
|
|
55
|
+
services.settings.setAppState('active_workspace_id', null);
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
addWorker: (workspaceId, input) => services.workspaceStore.addWorker(workspaceId, input),
|
|
59
|
+
addWorkerWithLaunch: (workspaceId, input, launchConfig) => {
|
|
60
|
+
// Atomic spawn: create the worker AND its launch config together so a
|
|
61
|
+
// failure can never persist a worker with no way to start it. The DB
|
|
62
|
+
// transaction rolls back the row; the catch prunes the in-memory worker
|
|
63
|
+
// that addWorker already pushed into the workspace record.
|
|
64
|
+
let worker;
|
|
65
|
+
try {
|
|
66
|
+
runDataMutation(() => {
|
|
67
|
+
worker = store.addWorker(workspaceId, input);
|
|
68
|
+
store.configureAgentLaunch(workspaceId, worker.id, launchConfig);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
if (worker) {
|
|
73
|
+
try {
|
|
74
|
+
store.deleteWorker(workspaceId, worker.id);
|
|
75
|
+
}
|
|
76
|
+
catch {
|
|
77
|
+
// The transaction already removed the DB row; this only prunes the
|
|
78
|
+
// stale in-memory entry, which may already be gone.
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
throw error;
|
|
82
|
+
}
|
|
83
|
+
if (!worker)
|
|
84
|
+
throw new Error('addWorkerWithLaunch produced no worker');
|
|
85
|
+
return worker;
|
|
86
|
+
},
|
|
87
|
+
renameWorker: (workspaceId, workerId, name) => services.workspaceStore.renameWorker(workspaceId, workerId, name),
|
|
88
|
+
deleteWorker: (workspaceId, workerId) => {
|
|
89
|
+
const activeRun = services.agentRuntime.getActiveRunByAgentId(workspaceId, workerId);
|
|
90
|
+
runDataMutation(() => {
|
|
91
|
+
services.dispatchLedgerStore.deleteWorkerDispatches(workspaceId, workerId);
|
|
92
|
+
services.workspaceStore.deleteWorker(workspaceId, workerId);
|
|
93
|
+
});
|
|
94
|
+
services.agentRuntime.deleteAgentLaunchConfig(workspaceId, workerId);
|
|
95
|
+
if (activeRun)
|
|
96
|
+
services.agentRuntime.stopAgentRun(activeRun.runId);
|
|
97
|
+
},
|
|
98
|
+
recordUserInput: services.teamOps.recordUserInput,
|
|
99
|
+
cancelTask: services.teamOps.cancelTask,
|
|
100
|
+
dispatchTask: services.teamOps.dispatchTask,
|
|
101
|
+
dispatchTaskByWorkerName: services.teamOps.dispatchTaskByWorkerName,
|
|
102
|
+
reportTask: services.teamOps.reportTask,
|
|
103
|
+
drainReportOutbox: services.teamOps.drainReportOutbox,
|
|
104
|
+
statusTask: services.teamOps.statusTask,
|
|
105
|
+
listDispatches: services.dispatchLedgerStore.listWorkspaceDispatches,
|
|
106
|
+
listWorkers: (workspaceId) => services.workspaceStore.listWorkers(workspaceId),
|
|
107
|
+
getLastPtyLineForAgent: (workspaceId, agentId) => services.workerOutputTracker?.getLastPtyLine(workspaceId, agentId) ?? null,
|
|
108
|
+
getWorkspaceSnapshot: (workspaceId) => services.workspaceStore.getWorkspaceSnapshot(workspaceId),
|
|
109
|
+
getWorker: (workspaceId, workerId) => services.workspaceStore.getWorker(workspaceId, workerId),
|
|
110
|
+
getAgent: (workspaceId, agentId) => services.workspaceStore.getAgent(workspaceId, agentId),
|
|
111
|
+
getPtyOutputBus: lifecycle.getPtyOutputBus,
|
|
112
|
+
listTerminalRuns: lifecycle.listTerminalRuns,
|
|
113
|
+
closeWorkspaceShell: lifecycle.closeWorkspaceShell,
|
|
114
|
+
configureAgentLaunch: lifecycle.configureAgentLaunch,
|
|
115
|
+
peekAgentLaunchConfig: lifecycle.peekAgentLaunchConfig,
|
|
116
|
+
startAgent: lifecycle.startAgent,
|
|
117
|
+
autostartConfiguredAgents: lifecycle.autostartConfiguredAgents,
|
|
118
|
+
startWorkspaceWatch: lifecycle.startWorkspaceWatch,
|
|
119
|
+
startWorkspaceShell: lifecycle.startWorkspaceShell,
|
|
120
|
+
getLiveRun: lifecycle.getLiveRun,
|
|
121
|
+
getActiveRunByAgentId: (workspaceId, agentId) => services.agentRuntime.getActiveRunByAgentId(workspaceId, agentId),
|
|
122
|
+
registerTasksListener: lifecycle.registerTasksListener,
|
|
123
|
+
listAgentRuns: (agentId) => services.agentRuntime.listAgentRuns(agentId),
|
|
124
|
+
listMessagesForRecovery: (workspaceId, sinceMs) => services.messageLogStore.listMessagesForRecovery(workspaceId, sinceMs),
|
|
125
|
+
recallMessages: (workspaceId, query, options) => services.teamRecallStore.recallMessages(workspaceId, query, options),
|
|
126
|
+
...createRuntimeStoreMemoryMethods(services),
|
|
127
|
+
...createRuntimeStoreDreamMethods(services),
|
|
128
|
+
peekAgentToken: (agentId) => services.agentRuntime.peekAgentToken(agentId),
|
|
129
|
+
pauseTerminalRun: lifecycle.pauseTerminalRun,
|
|
130
|
+
resizeAgentRun: lifecycle.resizeTerminalRun,
|
|
131
|
+
resumeTerminalRun: lifecycle.resumeTerminalRun,
|
|
132
|
+
settings: services.settings,
|
|
133
|
+
writeRunInput: lifecycle.writeRunInput,
|
|
134
|
+
getUiToken: () => services.uiAuth.getToken(),
|
|
135
|
+
stopAgentRun: lifecycle.stopTerminalRun,
|
|
136
|
+
validateAgentToken: (agentId, token) => services.agentRuntime.validateAgentToken(agentId, token),
|
|
137
|
+
validateUiToken: (token) => services.uiAuth.validate(token),
|
|
138
|
+
...createRuntimeStoreRemoteMethods(services),
|
|
139
|
+
getWorkflowDispatchAwaiter: () => services.workflowDispatchAwaiter,
|
|
140
|
+
runWorkflow: (input) => getWorkflowRuntime().runner.runWorkflow(input),
|
|
141
|
+
startWorkflow: (input) => getWorkflowRuntime().runner.startWorkflow(input),
|
|
142
|
+
startWorkflowInline: (input) => getWorkflowRuntime().runner.startWorkflowInline(input),
|
|
143
|
+
stopWorkflowRun: (runId) => getWorkflowRuntime().runner.stopRun(runId),
|
|
144
|
+
getWorkflowRun: (runId) => services.workflowRunStore.getRun(runId),
|
|
145
|
+
listWorkspaceWorkflowRuns: (workspaceId) => services.workflowRunStore.listWorkspaceRuns(workspaceId),
|
|
146
|
+
listWorkflowRunDispatches: (runId) => services.dispatchLedgerStore.listWorkflowRunDispatches(runId),
|
|
147
|
+
listWorkflowRunLogs: (runId) => services.workflowRunLogStore.listForRun(runId).map((row) => ({
|
|
148
|
+
id: row.id,
|
|
149
|
+
ts: row.ts,
|
|
150
|
+
message: row.message,
|
|
151
|
+
})),
|
|
152
|
+
createWorkflowSchedule: (input) => services.workflowScheduleStore.create(input),
|
|
153
|
+
scheduleWorkflowInline: (input) => persistWorkflowSchedule({
|
|
154
|
+
workspacePath: services.workspaceStore.getWorkspaceSnapshot(input.workspaceId).summary.path,
|
|
155
|
+
scheduleStore: services.workflowScheduleStore,
|
|
156
|
+
...input,
|
|
157
|
+
}),
|
|
158
|
+
updateWorkflowSchedule: (id, input) => services.workflowScheduleStore.update(id, input),
|
|
159
|
+
getWorkflowSchedule: (id) => services.workflowScheduleStore.get(id),
|
|
160
|
+
listWorkspaceWorkflowSchedules: (workspaceId) => services.workflowScheduleStore.listForWorkspace(workspaceId),
|
|
161
|
+
deleteWorkflowSchedule: (id) => services.workflowScheduleStore.deleteSchedule(id),
|
|
162
|
+
};
|
|
163
|
+
workflowRuntime = createRuntimeStoreWorkflowRuntime(services, store);
|
|
164
|
+
return store;
|
|
165
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
export declare const getClaudeProjectsRoot: (pattern?: string, platform?: NodeJS.Platform) => string;
|
|
2
|
+
/**
|
|
3
|
+
* Match the directory-name encoding Claude Code itself uses for its project
|
|
4
|
+
* metadata under `~/.claude/projects/`. Empirically (probed via `claude
|
|
5
|
+
* --print "x"` in directories named with each character) Claude Code
|
|
6
|
+
* replaces *every* character outside `[A-Za-z0-9-]` with a single `-`,
|
|
7
|
+
* one-for-one, preserving literal hyphens.
|
|
8
|
+
*
|
|
9
|
+
* The previous regex `[\\/:\s]` only matched `\`, `/`, `:`, and whitespace —
|
|
10
|
+
* leaving `_`, `.`, parens, brackets, `@`, `#`, `&`, `+`, and any non-ASCII
|
|
11
|
+
* character (including CJK usernames) intact, while Claude Code's own
|
|
12
|
+
* encoder replaced them. The mismatch meant Hive looked for sessions under
|
|
13
|
+
* a different directory than the one Claude Code wrote to, so session
|
|
14
|
+
* resume silently failed for any workspace path containing those chars.
|
|
15
|
+
* Windows + CJK Windows usernames (`C:\Users\张三\project`) and
|
|
16
|
+
* underscored Windows project paths (`C:\my_project`) are the most common
|
|
17
|
+
* triggers, but the bug is cross-platform.
|
|
18
|
+
*
|
|
19
|
+
* Backward compatibility: workspaces whose path contains ONLY chars that
|
|
20
|
+
* the old regex already matched (`/\:` + whitespace) get the same encoded
|
|
21
|
+
* dirname as before — no behavior change. Workspaces with any other
|
|
22
|
+
* special chars previously had broken session resume; the fix moves them
|
|
23
|
+
* to the correct (working) directory.
|
|
24
|
+
*/
|
|
25
|
+
export declare const encodeClaudeProjectPath: (cwd: string) => string;
|
|
26
|
+
interface ClaudeSessionCaptureDiscriminator {
|
|
27
|
+
contentIncludes?: string | readonly string[];
|
|
28
|
+
}
|
|
29
|
+
export declare const getClaudeSessionFilePath: (cwd: string, sessionId: string, pattern?: string) => string;
|
|
30
|
+
export declare const hasClaudeSessionFile: (cwd: string, sessionId: string, pattern?: string, discriminator?: ClaudeSessionCaptureDiscriminator) => boolean;
|
|
31
|
+
export declare const captureClaudeSessionId: (cwd: string, knownSessionIds: Set<string>, onCapture: (sessionId: string) => void, timeoutMs?: number, intervalMs?: number, projectsRoot?: string, discriminator?: ClaudeSessionCaptureDiscriminator) => Promise<void>;
|
|
32
|
+
export declare const snapshotClaudeSessionIds: (cwd: string, projectsRoot?: string) => Set<string>;
|
|
33
|
+
export declare const resetClaudeSessionClaimsForTests: () => void;
|
|
34
|
+
export {};
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync } from 'node:fs';
|
|
2
|
+
import { homedir } from 'node:os';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { captureSessionIdWithCoordinator, resetSessionCaptureCoordinatorForTests, } from './claude-session-coordinator.js';
|
|
5
|
+
import { arePathsEqual, expandHomePath } from './platform-path.js';
|
|
6
|
+
const SESSION_FILE = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}\.jsonl$/i;
|
|
7
|
+
const getDefaultProjectsRoot = () => process.env.HIVE_CLAUDE_PROJECTS_DIR ?? join(homedir(), '.claude/projects');
|
|
8
|
+
export const getClaudeProjectsRoot = (pattern, platform = process.platform) => {
|
|
9
|
+
if (!pattern)
|
|
10
|
+
return getDefaultProjectsRoot();
|
|
11
|
+
const markerIndex = pattern.indexOf('{encoded_cwd}');
|
|
12
|
+
if (markerIndex === -1)
|
|
13
|
+
return getDefaultProjectsRoot();
|
|
14
|
+
const root = pattern.slice(0, markerIndex).replace(/[\\/]+$/, '');
|
|
15
|
+
if (!root)
|
|
16
|
+
return getDefaultProjectsRoot();
|
|
17
|
+
const builtInProjectsRoot = join(homedir(), '.claude', 'projects');
|
|
18
|
+
const expandedRoot = expandHomePath(root);
|
|
19
|
+
if (root === '~' || arePathsEqual(expandedRoot, builtInProjectsRoot, platform)) {
|
|
20
|
+
return getDefaultProjectsRoot();
|
|
21
|
+
}
|
|
22
|
+
return expandedRoot;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Match the directory-name encoding Claude Code itself uses for its project
|
|
26
|
+
* metadata under `~/.claude/projects/`. Empirically (probed via `claude
|
|
27
|
+
* --print "x"` in directories named with each character) Claude Code
|
|
28
|
+
* replaces *every* character outside `[A-Za-z0-9-]` with a single `-`,
|
|
29
|
+
* one-for-one, preserving literal hyphens.
|
|
30
|
+
*
|
|
31
|
+
* The previous regex `[\\/:\s]` only matched `\`, `/`, `:`, and whitespace —
|
|
32
|
+
* leaving `_`, `.`, parens, brackets, `@`, `#`, `&`, `+`, and any non-ASCII
|
|
33
|
+
* character (including CJK usernames) intact, while Claude Code's own
|
|
34
|
+
* encoder replaced them. The mismatch meant Hive looked for sessions under
|
|
35
|
+
* a different directory than the one Claude Code wrote to, so session
|
|
36
|
+
* resume silently failed for any workspace path containing those chars.
|
|
37
|
+
* Windows + CJK Windows usernames (`C:\Users\张三\project`) and
|
|
38
|
+
* underscored Windows project paths (`C:\my_project`) are the most common
|
|
39
|
+
* triggers, but the bug is cross-platform.
|
|
40
|
+
*
|
|
41
|
+
* Backward compatibility: workspaces whose path contains ONLY chars that
|
|
42
|
+
* the old regex already matched (`/\:` + whitespace) get the same encoded
|
|
43
|
+
* dirname as before — no behavior change. Workspaces with any other
|
|
44
|
+
* special chars previously had broken session resume; the fix moves them
|
|
45
|
+
* to the correct (working) directory.
|
|
46
|
+
*/
|
|
47
|
+
export const encodeClaudeProjectPath = (cwd) => cwd.replace(/[^A-Za-z0-9-]/g, '-');
|
|
48
|
+
const listSessionIds = (cwd, projectsRoot = getDefaultProjectsRoot()) => {
|
|
49
|
+
const projectDir = join(projectsRoot, encodeClaudeProjectPath(cwd));
|
|
50
|
+
try {
|
|
51
|
+
return readdirSync(projectDir, { withFileTypes: true })
|
|
52
|
+
.filter((entry) => entry.isFile() && SESSION_FILE.test(entry.name))
|
|
53
|
+
.map((entry) => entry.name.replace(/\.jsonl$/i, ''))
|
|
54
|
+
.sort((left, right) => left.localeCompare(right));
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return [];
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
const includesAny = (content, needles) => {
|
|
61
|
+
const normalizedNeedles = Array.isArray(needles) ? needles : [needles];
|
|
62
|
+
return normalizedNeedles.some((needle) => content.includes(needle));
|
|
63
|
+
};
|
|
64
|
+
const sessionFileContainsAny = (cwd, projectsRoot, sessionId, contentIncludes) => {
|
|
65
|
+
try {
|
|
66
|
+
const content = readFileSync(join(projectsRoot, encodeClaudeProjectPath(cwd), `${sessionId}.jsonl`), 'utf8');
|
|
67
|
+
return includesAny(content, contentIncludes);
|
|
68
|
+
}
|
|
69
|
+
catch {
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
export const getClaudeSessionFilePath = (cwd, sessionId, pattern) => join(getClaudeProjectsRoot(pattern), encodeClaudeProjectPath(cwd), `${sessionId}.jsonl`);
|
|
74
|
+
export const hasClaudeSessionFile = (cwd, sessionId, pattern, discriminator = {}) => {
|
|
75
|
+
if (!SESSION_FILE.test(`${sessionId}.jsonl`) ||
|
|
76
|
+
!existsSync(getClaudeSessionFilePath(cwd, sessionId, pattern))) {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
const projectsRoot = getClaudeProjectsRoot(pattern);
|
|
80
|
+
return discriminator.contentIncludes
|
|
81
|
+
? sessionFileContainsAny(cwd, projectsRoot, sessionId, discriminator.contentIncludes)
|
|
82
|
+
: true;
|
|
83
|
+
};
|
|
84
|
+
export const captureClaudeSessionId = async (cwd, knownSessionIds, onCapture, timeoutMs = 5000, intervalMs = 100, projectsRoot = getDefaultProjectsRoot(), discriminator = {}) => {
|
|
85
|
+
const contentIncludes = discriminator.contentIncludes;
|
|
86
|
+
await captureSessionIdWithCoordinator({
|
|
87
|
+
intervalMs,
|
|
88
|
+
knownSessionIds,
|
|
89
|
+
listSessionIds: () => listSessionIds(cwd, projectsRoot),
|
|
90
|
+
onCapture,
|
|
91
|
+
projectKey: join(projectsRoot, encodeClaudeProjectPath(cwd)),
|
|
92
|
+
timeoutMs,
|
|
93
|
+
...(contentIncludes
|
|
94
|
+
? {
|
|
95
|
+
matchesSessionId: (sessionId) => sessionFileContainsAny(cwd, projectsRoot, sessionId, contentIncludes),
|
|
96
|
+
}
|
|
97
|
+
: {}),
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
export const snapshotClaudeSessionIds = (cwd, projectsRoot = getDefaultProjectsRoot()) => new Set(listSessionIds(cwd, projectsRoot));
|
|
101
|
+
export const resetClaudeSessionClaimsForTests = () => {
|
|
102
|
+
resetSessionCaptureCoordinatorForTests();
|
|
103
|
+
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const getCodexHome: (pattern?: string, platform?: NodeJS.Platform) => string;
|
|
2
|
+
export declare const readCodexSessionFirstLine: (filePath: string, maxBytes?: number) => string | null;
|
|
3
|
+
export declare const hasCodexSession: (cwd: string, sessionId: string, pattern?: string, platform?: NodeJS.Platform, codexHome?: string) => boolean;
|
|
4
|
+
export declare const snapshotCodexSessionIds: (cwd: string, codexHome?: string, platform?: NodeJS.Platform) => Set<string>;
|
|
5
|
+
export declare const captureCodexSessionId: (cwd: string, knownSessionIds: Set<string>, onCapture: (sessionId: string) => void, timeoutMs?: number, intervalMs?: number, codexHome?: string) => Promise<void>;
|
|
6
|
+
export declare const codexSessionStoreExists: (codexHome?: string) => boolean;
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { closeSync, existsSync, openSync, readdirSync, readSync } from 'node:fs';
|
|
2
|
+
import { homedir } from 'node:os';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { captureSessionIdWithCoordinator } from './claude-session-coordinator.js';
|
|
5
|
+
import { arePathsEqual, expandHomePath, indexOfPathMarker } from './platform-path.js';
|
|
6
|
+
const CODEX_SESSION_FILE = /^rollout-.*\.jsonl$/i;
|
|
7
|
+
const CODEX_SESSIONS_MARKER = '/sessions/';
|
|
8
|
+
const CODEX_HEADER_READ_CHUNK_BYTES = 4096;
|
|
9
|
+
const CODEX_HEADER_MAX_BYTES = 64 * 1024;
|
|
10
|
+
const getDefaultCodexHome = () => process.env.CODEX_HOME ?? join(homedir(), '.codex');
|
|
11
|
+
export const getCodexHome = (pattern, platform = process.platform) => {
|
|
12
|
+
if (!pattern)
|
|
13
|
+
return getDefaultCodexHome();
|
|
14
|
+
const markerIndex = indexOfPathMarker(pattern, CODEX_SESSIONS_MARKER, platform);
|
|
15
|
+
if (markerIndex === -1)
|
|
16
|
+
return getDefaultCodexHome();
|
|
17
|
+
const rawRoot = pattern.slice(0, markerIndex).replace(/[\\/]+$/u, '');
|
|
18
|
+
const root = expandHomePath(rawRoot);
|
|
19
|
+
if (arePathsEqual(root, join(homedir(), '.codex'), platform))
|
|
20
|
+
return getDefaultCodexHome();
|
|
21
|
+
return root || getDefaultCodexHome();
|
|
22
|
+
};
|
|
23
|
+
const walkSessionFiles = (dir) => {
|
|
24
|
+
try {
|
|
25
|
+
return readdirSync(dir, { withFileTypes: true }).flatMap((entry) => {
|
|
26
|
+
const path = join(dir, entry.name);
|
|
27
|
+
if (entry.isDirectory())
|
|
28
|
+
return walkSessionFiles(path);
|
|
29
|
+
return entry.isFile() && CODEX_SESSION_FILE.test(entry.name) ? [path] : [];
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
return [];
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
export const readCodexSessionFirstLine = (filePath, maxBytes = CODEX_HEADER_MAX_BYTES) => {
|
|
37
|
+
const fd = openSync(filePath, 'r');
|
|
38
|
+
try {
|
|
39
|
+
const chunks = [];
|
|
40
|
+
let totalBytes = 0;
|
|
41
|
+
let position = 0;
|
|
42
|
+
let reachedLineEnd = false;
|
|
43
|
+
while (totalBytes < maxBytes) {
|
|
44
|
+
const bytesToRead = Math.min(CODEX_HEADER_READ_CHUNK_BYTES, maxBytes - totalBytes);
|
|
45
|
+
const buffer = Buffer.allocUnsafe(bytesToRead);
|
|
46
|
+
const bytesRead = readSync(fd, buffer, 0, bytesToRead, position);
|
|
47
|
+
if (bytesRead === 0) {
|
|
48
|
+
reachedLineEnd = true;
|
|
49
|
+
break;
|
|
50
|
+
}
|
|
51
|
+
const slice = buffer.subarray(0, bytesRead);
|
|
52
|
+
const newlineIndex = slice.indexOf(0x0a);
|
|
53
|
+
if (newlineIndex >= 0) {
|
|
54
|
+
chunks.push(slice.subarray(0, newlineIndex));
|
|
55
|
+
reachedLineEnd = true;
|
|
56
|
+
break;
|
|
57
|
+
}
|
|
58
|
+
chunks.push(slice);
|
|
59
|
+
totalBytes += bytesRead;
|
|
60
|
+
position += bytesRead;
|
|
61
|
+
}
|
|
62
|
+
if (!reachedLineEnd)
|
|
63
|
+
return null;
|
|
64
|
+
return Buffer.concat(chunks).toString('utf8').replace(/\r$/, '');
|
|
65
|
+
}
|
|
66
|
+
finally {
|
|
67
|
+
closeSync(fd);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
const parseCodexSession = (filePath) => {
|
|
71
|
+
const firstLine = readCodexSessionFirstLine(filePath) ?? '';
|
|
72
|
+
const parsed = JSON.parse(firstLine);
|
|
73
|
+
if (!parsed || typeof parsed !== 'object' || !('payload' in parsed))
|
|
74
|
+
return null;
|
|
75
|
+
const payload = parsed.payload;
|
|
76
|
+
if (!payload || typeof payload !== 'object')
|
|
77
|
+
return null;
|
|
78
|
+
const id = 'id' in payload && typeof payload.id === 'string' ? payload.id : null;
|
|
79
|
+
const cwd = 'cwd' in payload && typeof payload.cwd === 'string' ? payload.cwd : null;
|
|
80
|
+
return id && cwd ? { cwd, id } : null;
|
|
81
|
+
};
|
|
82
|
+
const listSessionIds = (cwd, codexHome = getDefaultCodexHome(), platform = process.platform) => {
|
|
83
|
+
const sessionsRoot = join(codexHome, 'sessions');
|
|
84
|
+
return walkSessionFiles(sessionsRoot)
|
|
85
|
+
.flatMap((filePath) => {
|
|
86
|
+
try {
|
|
87
|
+
const session = parseCodexSession(filePath);
|
|
88
|
+
return session && arePathsEqual(session.cwd, cwd, platform) ? [session.id] : [];
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
return [];
|
|
92
|
+
}
|
|
93
|
+
})
|
|
94
|
+
.sort((left, right) => left.localeCompare(right));
|
|
95
|
+
};
|
|
96
|
+
export const hasCodexSession = (cwd, sessionId, pattern, platform = process.platform, codexHome = getCodexHome(pattern, platform)) => listSessionIds(cwd, codexHome, platform).includes(sessionId);
|
|
97
|
+
export const snapshotCodexSessionIds = (cwd, codexHome = getDefaultCodexHome(), platform = process.platform) => new Set(listSessionIds(cwd, codexHome, platform));
|
|
98
|
+
export const captureCodexSessionId = async (cwd, knownSessionIds, onCapture, timeoutMs = 5000, intervalMs = 100, codexHome = getDefaultCodexHome()) => {
|
|
99
|
+
await captureSessionIdWithCoordinator({
|
|
100
|
+
intervalMs,
|
|
101
|
+
knownSessionIds,
|
|
102
|
+
listSessionIds: () => listSessionIds(cwd, codexHome),
|
|
103
|
+
onCapture,
|
|
104
|
+
projectKey: join(codexHome, 'sessions', cwd),
|
|
105
|
+
timeoutMs,
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
export const codexSessionStoreExists = (codexHome = getDefaultCodexHome()) => existsSync(join(codexHome, 'sessions'));
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare const getGeminiHome: (pattern?: string, platform?: NodeJS.Platform) => string;
|
|
2
|
+
export declare const hasGeminiSession: (cwd: string, sessionId: string, pattern?: string) => boolean;
|
|
3
|
+
export declare const snapshotGeminiSessionIds: (cwd: string, geminiHome?: string) => Set<string>;
|
|
4
|
+
export declare const captureGeminiSessionId: (cwd: string, knownSessionIds: Set<string>, onCapture: (sessionId: string) => void, timeoutMs?: number, intervalMs?: number, geminiHome?: string) => Promise<void>;
|
|
5
|
+
export declare const geminiSessionStoreExists: (geminiHome?: string) => boolean;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync } from 'node:fs';
|
|
2
|
+
import { homedir } from 'node:os';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { captureSessionIdWithCoordinator } from './claude-session-coordinator.js';
|
|
5
|
+
import { arePathsEqual, expandHomePath, indexOfPathMarker } from './platform-path.js';
|
|
6
|
+
const GEMINI_SESSION_FILE = /^session-.*\.json$/i;
|
|
7
|
+
const GEMINI_TMP_MARKER = '/tmp/';
|
|
8
|
+
const getDefaultGeminiHome = () => process.env.HIVE_GEMINI_HOME ?? join(homedir(), '.gemini');
|
|
9
|
+
export const getGeminiHome = (pattern, platform = process.platform) => {
|
|
10
|
+
if (!pattern)
|
|
11
|
+
return getDefaultGeminiHome();
|
|
12
|
+
const markerIndex = indexOfPathMarker(pattern, GEMINI_TMP_MARKER, platform);
|
|
13
|
+
if (markerIndex === -1)
|
|
14
|
+
return getDefaultGeminiHome();
|
|
15
|
+
const rawRoot = pattern.slice(0, markerIndex).replace(/[\\/]+$/u, '');
|
|
16
|
+
const root = expandHomePath(rawRoot);
|
|
17
|
+
if (arePathsEqual(root, join(homedir(), '.gemini'), platform))
|
|
18
|
+
return getDefaultGeminiHome();
|
|
19
|
+
return root || getDefaultGeminiHome();
|
|
20
|
+
};
|
|
21
|
+
const readProjectRoot = (projectDir) => {
|
|
22
|
+
try {
|
|
23
|
+
return readFileSync(join(projectDir, '.project_root'), 'utf8').trim();
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
const parseGeminiSessionId = (filePath) => {
|
|
30
|
+
const parsed = JSON.parse(readFileSync(filePath, 'utf8'));
|
|
31
|
+
if (!parsed || typeof parsed !== 'object')
|
|
32
|
+
return null;
|
|
33
|
+
return 'sessionId' in parsed && typeof parsed.sessionId === 'string' ? parsed.sessionId : null;
|
|
34
|
+
};
|
|
35
|
+
const listSessionIds = (cwd, geminiHome = getDefaultGeminiHome()) => {
|
|
36
|
+
const tmpRoot = join(geminiHome, 'tmp');
|
|
37
|
+
try {
|
|
38
|
+
return readdirSync(tmpRoot, { withFileTypes: true })
|
|
39
|
+
.filter((entry) => entry.isDirectory())
|
|
40
|
+
.flatMap((entry) => {
|
|
41
|
+
const projectDir = join(tmpRoot, entry.name);
|
|
42
|
+
const projectRoot = readProjectRoot(projectDir);
|
|
43
|
+
if (projectRoot === null || !arePathsEqual(projectRoot, cwd))
|
|
44
|
+
return [];
|
|
45
|
+
const chatsDir = join(projectDir, 'chats');
|
|
46
|
+
try {
|
|
47
|
+
return readdirSync(chatsDir, { withFileTypes: true }).flatMap((chat) => {
|
|
48
|
+
if (!chat.isFile() || !GEMINI_SESSION_FILE.test(chat.name))
|
|
49
|
+
return [];
|
|
50
|
+
try {
|
|
51
|
+
const sessionId = parseGeminiSessionId(join(chatsDir, chat.name));
|
|
52
|
+
return sessionId ? [sessionId] : [];
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
return [];
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
catch {
|
|
60
|
+
return [];
|
|
61
|
+
}
|
|
62
|
+
})
|
|
63
|
+
.sort((left, right) => left.localeCompare(right));
|
|
64
|
+
}
|
|
65
|
+
catch {
|
|
66
|
+
return [];
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
export const hasGeminiSession = (cwd, sessionId, pattern) => listSessionIds(cwd, getGeminiHome(pattern)).includes(sessionId);
|
|
70
|
+
export const snapshotGeminiSessionIds = (cwd, geminiHome = getDefaultGeminiHome()) => new Set(listSessionIds(cwd, geminiHome));
|
|
71
|
+
export const captureGeminiSessionId = async (cwd, knownSessionIds, onCapture, timeoutMs = 5000, intervalMs = 100, geminiHome = getDefaultGeminiHome()) => {
|
|
72
|
+
await captureSessionIdWithCoordinator({
|
|
73
|
+
intervalMs,
|
|
74
|
+
knownSessionIds,
|
|
75
|
+
listSessionIds: () => listSessionIds(cwd, geminiHome),
|
|
76
|
+
onCapture,
|
|
77
|
+
projectKey: join(geminiHome, 'tmp', cwd),
|
|
78
|
+
timeoutMs,
|
|
79
|
+
});
|
|
80
|
+
};
|
|
81
|
+
export const geminiSessionStoreExists = (geminiHome = getDefaultGeminiHome()) => existsSync(join(geminiHome, 'tmp'));
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Resolve the path OpenCode upstream writes `opencode.db` to. Branches
|
|
3
|
+
* by platform because XDG_DATA_HOME is not a Windows convention — the
|
|
4
|
+
* previous unconditional ~/.local/share/opencode/opencode.db default
|
|
5
|
+
* pointed at a path that never exists on Windows, silently breaking
|
|
6
|
+
* Layer A native session resume for OpenCode workers there.
|
|
7
|
+
*
|
|
8
|
+
* Resolution order:
|
|
9
|
+
* 1. HIVE_OPENCODE_DB_PATH override (any platform, for tests/users).
|
|
10
|
+
* 2. Windows: %LOCALAPPDATA%\opencode\opencode.db (with a homedir
|
|
11
|
+
* fallback when LOCALAPPDATA is missing — some shells strip env).
|
|
12
|
+
* 3. POSIX: $XDG_DATA_HOME/opencode/opencode.db, falling back to
|
|
13
|
+
* ~/.local/share/opencode/opencode.db.
|
|
14
|
+
*
|
|
15
|
+
* Exported so the path-resolution rules can be unit-tested without
|
|
16
|
+
* needing to mock the underlying SQLite open.
|
|
17
|
+
*/
|
|
18
|
+
export declare const getDefaultOpenCodeDbPath: (platform?: NodeJS.Platform) => string;
|
|
19
|
+
export declare const getOpenCodeDbPath: (pattern?: string, platform?: NodeJS.Platform) => string;
|
|
20
|
+
export declare const hasOpenCodeSession: (cwd: string, sessionId: string, pattern?: string, platform?: NodeJS.Platform, dbPath?: string) => boolean;
|
|
21
|
+
export declare const snapshotOpenCodeSessionIds: (cwd: string, dbPath?: string, platform?: NodeJS.Platform) => Set<string>;
|
|
22
|
+
export declare const captureOpenCodeSessionId: (cwd: string, knownSessionIds: Set<string>, onCapture: (sessionId: string) => void, timeoutMs?: number, intervalMs?: number, dbPath?: string, platform?: NodeJS.Platform) => Promise<void>;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { existsSync } from 'node:fs';
|
|
2
|
+
import { homedir } from 'node:os';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import Database from 'better-sqlite3';
|
|
5
|
+
import { captureSessionIdWithCoordinator } from './claude-session-coordinator.js';
|
|
6
|
+
import { arePathsEqual, expandHomePath } from './platform-path.js';
|
|
7
|
+
/**
|
|
8
|
+
* Resolve the path OpenCode upstream writes `opencode.db` to. Branches
|
|
9
|
+
* by platform because XDG_DATA_HOME is not a Windows convention — the
|
|
10
|
+
* previous unconditional ~/.local/share/opencode/opencode.db default
|
|
11
|
+
* pointed at a path that never exists on Windows, silently breaking
|
|
12
|
+
* Layer A native session resume for OpenCode workers there.
|
|
13
|
+
*
|
|
14
|
+
* Resolution order:
|
|
15
|
+
* 1. HIVE_OPENCODE_DB_PATH override (any platform, for tests/users).
|
|
16
|
+
* 2. Windows: %LOCALAPPDATA%\opencode\opencode.db (with a homedir
|
|
17
|
+
* fallback when LOCALAPPDATA is missing — some shells strip env).
|
|
18
|
+
* 3. POSIX: $XDG_DATA_HOME/opencode/opencode.db, falling back to
|
|
19
|
+
* ~/.local/share/opencode/opencode.db.
|
|
20
|
+
*
|
|
21
|
+
* Exported so the path-resolution rules can be unit-tested without
|
|
22
|
+
* needing to mock the underlying SQLite open.
|
|
23
|
+
*/
|
|
24
|
+
export const getDefaultOpenCodeDbPath = (platform = process.platform) => {
|
|
25
|
+
const override = process.env.HIVE_OPENCODE_DB_PATH;
|
|
26
|
+
if (override)
|
|
27
|
+
return override;
|
|
28
|
+
if (platform === 'win32') {
|
|
29
|
+
const localAppData = process.env.LOCALAPPDATA ?? join(homedir(), 'AppData', 'Local');
|
|
30
|
+
return join(localAppData, 'opencode', 'opencode.db');
|
|
31
|
+
}
|
|
32
|
+
return join(process.env.XDG_DATA_HOME ?? join(homedir(), '.local', 'share'), 'opencode', 'opencode.db');
|
|
33
|
+
};
|
|
34
|
+
export const getOpenCodeDbPath = (pattern, platform = process.platform) => {
|
|
35
|
+
if (!pattern)
|
|
36
|
+
return getDefaultOpenCodeDbPath(platform);
|
|
37
|
+
const expanded = expandHomePath(pattern);
|
|
38
|
+
if (arePathsEqual(expanded, join(homedir(), '.local', 'share', 'opencode', 'opencode.db'), platform)) {
|
|
39
|
+
return getDefaultOpenCodeDbPath(platform);
|
|
40
|
+
}
|
|
41
|
+
return expanded;
|
|
42
|
+
};
|
|
43
|
+
const listSessionIds = (cwd, dbPath = getDefaultOpenCodeDbPath(), platform = process.platform) => {
|
|
44
|
+
if (!existsSync(dbPath))
|
|
45
|
+
return [];
|
|
46
|
+
let db;
|
|
47
|
+
try {
|
|
48
|
+
db = new Database(dbPath, { fileMustExist: true, readonly: true });
|
|
49
|
+
return db
|
|
50
|
+
.prepare(`SELECT id, directory FROM session
|
|
51
|
+
WHERE time_archived IS NULL
|
|
52
|
+
ORDER BY rowid ASC`)
|
|
53
|
+
.all()
|
|
54
|
+
.filter((row) => arePathsEqual(row.directory, cwd, platform))
|
|
55
|
+
.map((row) => row.id);
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
return [];
|
|
59
|
+
}
|
|
60
|
+
finally {
|
|
61
|
+
db?.close();
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
export const hasOpenCodeSession = (cwd, sessionId, pattern, platform = process.platform, dbPath = getOpenCodeDbPath(pattern, platform)) => listSessionIds(cwd, dbPath, platform).includes(sessionId);
|
|
65
|
+
export const snapshotOpenCodeSessionIds = (cwd, dbPath = getDefaultOpenCodeDbPath(), platform = process.platform) => new Set(listSessionIds(cwd, dbPath, platform));
|
|
66
|
+
export const captureOpenCodeSessionId = async (cwd, knownSessionIds, onCapture, timeoutMs = 5000, intervalMs = 100, dbPath = getDefaultOpenCodeDbPath(), platform = process.platform) => {
|
|
67
|
+
await captureSessionIdWithCoordinator({
|
|
68
|
+
intervalMs,
|
|
69
|
+
knownSessionIds,
|
|
70
|
+
listSessionIds: () => listSessionIds(cwd, dbPath, platform),
|
|
71
|
+
onCapture,
|
|
72
|
+
projectKey: `${dbPath}:${cwd}`,
|
|
73
|
+
timeoutMs,
|
|
74
|
+
});
|
|
75
|
+
};
|