zero-workspace 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +18 -0
- package/README.md +187 -0
- package/config/component-versions.json +16 -0
- package/config/scenarioCapabilities.json +29 -0
- package/config/version-notes.yaml +244 -0
- package/dist/adapters/OutputAdapter.d.ts +79 -0
- package/dist/adapters/OutputAdapter.d.ts.map +1 -0
- package/dist/adapters/OutputAdapter.js +124 -0
- package/dist/adapters/OutputAdapter.js.map +1 -0
- package/dist/cli/check-node-version.d.ts +3 -0
- package/dist/cli/check-node-version.d.ts.map +1 -0
- package/dist/cli/check-node-version.js +153 -0
- package/dist/cli/check-node-version.js.map +1 -0
- package/dist/cli/plugins.d.ts +41 -0
- package/dist/cli/plugins.d.ts.map +1 -0
- package/dist/cli/plugins.js +742 -0
- package/dist/cli/plugins.js.map +1 -0
- package/dist/cli/rebuild.d.ts +63 -0
- package/dist/cli/rebuild.d.ts.map +1 -0
- package/dist/cli/rebuild.js +989 -0
- package/dist/cli/rebuild.js.map +1 -0
- package/dist/cli/repair.d.ts +7 -0
- package/dist/cli/repair.d.ts.map +1 -0
- package/dist/cli/repair.js +925 -0
- package/dist/cli/repair.js.map +1 -0
- package/dist/cli/setup.d.ts +7 -0
- package/dist/cli/setup.d.ts.map +1 -0
- package/dist/cli/setup.js +452 -0
- package/dist/cli/setup.js.map +1 -0
- package/dist/cli/update.d.ts +10 -0
- package/dist/cli/update.d.ts.map +1 -0
- package/dist/cli/update.js +426 -0
- package/dist/cli/update.js.map +1 -0
- package/dist/cli/webui.d.ts +6 -0
- package/dist/cli/webui.d.ts.map +1 -0
- package/dist/cli/webui.js +210 -0
- package/dist/cli/webui.js.map +1 -0
- package/dist/http/index.d.ts +3 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +15 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/middleware/errorHandler.d.ts +16 -0
- package/dist/http/middleware/errorHandler.d.ts.map +1 -0
- package/dist/http/middleware/errorHandler.js +79 -0
- package/dist/http/middleware/errorHandler.js.map +1 -0
- package/dist/http/routes/admin.d.ts +3 -0
- package/dist/http/routes/admin.d.ts.map +1 -0
- package/dist/http/routes/admin.js +730 -0
- package/dist/http/routes/admin.js.map +1 -0
- package/dist/http/routes/backup.d.ts +3 -0
- package/dist/http/routes/backup.d.ts.map +1 -0
- package/dist/http/routes/backup.js +172 -0
- package/dist/http/routes/backup.js.map +1 -0
- package/dist/http/routes/config.d.ts +3 -0
- package/dist/http/routes/config.d.ts.map +1 -0
- package/dist/http/routes/config.js +157 -0
- package/dist/http/routes/config.js.map +1 -0
- package/dist/http/routes/context.d.ts +3 -0
- package/dist/http/routes/context.d.ts.map +1 -0
- package/dist/http/routes/context.js +82 -0
- package/dist/http/routes/context.js.map +1 -0
- package/dist/http/routes/log.d.ts +3 -0
- package/dist/http/routes/log.d.ts.map +1 -0
- package/dist/http/routes/log.js +105 -0
- package/dist/http/routes/log.js.map +1 -0
- package/dist/http/routes/memo.d.ts +6 -0
- package/dist/http/routes/memo.d.ts.map +1 -0
- package/dist/http/routes/memo.js +29 -0
- package/dist/http/routes/memo.js.map +1 -0
- package/dist/http/routes/node.d.ts +3 -0
- package/dist/http/routes/node.d.ts.map +1 -0
- package/dist/http/routes/node.js +251 -0
- package/dist/http/routes/node.js.map +1 -0
- package/dist/http/routes/state.d.ts +3 -0
- package/dist/http/routes/state.d.ts.map +1 -0
- package/dist/http/routes/state.js +48 -0
- package/dist/http/routes/state.js.map +1 -0
- package/dist/http/routes/workspace.d.ts +3 -0
- package/dist/http/routes/workspace.d.ts.map +1 -0
- package/dist/http/routes/workspace.js +249 -0
- package/dist/http/routes/workspace.js.map +1 -0
- package/dist/http/server.d.ts +10 -0
- package/dist/http/server.d.ts.map +1 -0
- package/dist/http/server.js +284 -0
- package/dist/http/server.js.map +1 -0
- package/dist/http/services.d.ts +93 -0
- package/dist/http/services.d.ts.map +1 -0
- package/dist/http/services.js +297 -0
- package/dist/http/services.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1073 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/guidanceContent.d.ts +18 -0
- package/dist/prompts/guidanceContent.d.ts.map +1 -0
- package/dist/prompts/guidanceContent.js +814 -0
- package/dist/prompts/guidanceContent.js.map +1 -0
- package/dist/prompts/index.d.ts +2 -0
- package/dist/prompts/index.d.ts.map +1 -0
- package/dist/prompts/index.js +4 -0
- package/dist/prompts/index.js.map +1 -0
- package/dist/prompts/instructions.d.ts +56 -0
- package/dist/prompts/instructions.d.ts.map +1 -0
- package/dist/prompts/instructions.js +1343 -0
- package/dist/prompts/instructions.js.map +1 -0
- package/dist/services/BackupService.d.ts +104 -0
- package/dist/services/BackupService.d.ts.map +1 -0
- package/dist/services/BackupService.js +549 -0
- package/dist/services/BackupService.js.map +1 -0
- package/dist/services/CapabilityService.d.ts +38 -0
- package/dist/services/CapabilityService.d.ts.map +1 -0
- package/dist/services/CapabilityService.js +256 -0
- package/dist/services/CapabilityService.js.map +1 -0
- package/dist/services/ConfigService.d.ts +35 -0
- package/dist/services/ConfigService.d.ts.map +1 -0
- package/dist/services/ConfigService.js +105 -0
- package/dist/services/ConfigService.js.map +1 -0
- package/dist/services/ContextService.d.ts +65 -0
- package/dist/services/ContextService.d.ts.map +1 -0
- package/dist/services/ContextService.js +503 -0
- package/dist/services/ContextService.js.map +1 -0
- package/dist/services/DetectionService.d.ts +76 -0
- package/dist/services/DetectionService.d.ts.map +1 -0
- package/dist/services/DetectionService.js +262 -0
- package/dist/services/DetectionService.js.map +1 -0
- package/dist/services/DispatchService.d.ts +267 -0
- package/dist/services/DispatchService.d.ts.map +1 -0
- package/dist/services/DispatchService.js +1357 -0
- package/dist/services/DispatchService.js.map +1 -0
- package/dist/services/EventService.d.ts +81 -0
- package/dist/services/EventService.d.ts.map +1 -0
- package/dist/services/EventService.js +187 -0
- package/dist/services/EventService.js.map +1 -0
- package/dist/services/GuidanceService.d.ts +64 -0
- package/dist/services/GuidanceService.d.ts.map +1 -0
- package/dist/services/GuidanceService.js +259 -0
- package/dist/services/GuidanceService.js.map +1 -0
- package/dist/services/HealthService.d.ts +43 -0
- package/dist/services/HealthService.d.ts.map +1 -0
- package/dist/services/HealthService.js +276 -0
- package/dist/services/HealthService.js.map +1 -0
- package/dist/services/InstallationService.d.ts +62 -0
- package/dist/services/InstallationService.d.ts.map +1 -0
- package/dist/services/InstallationService.js +204 -0
- package/dist/services/InstallationService.js.map +1 -0
- package/dist/services/LogService.d.ts +35 -0
- package/dist/services/LogService.d.ts.map +1 -0
- package/dist/services/LogService.js +189 -0
- package/dist/services/LogService.js.map +1 -0
- package/dist/services/MemoService.d.ts +39 -0
- package/dist/services/MemoService.d.ts.map +1 -0
- package/dist/services/MemoService.js +288 -0
- package/dist/services/MemoService.js.map +1 -0
- package/dist/services/NodeService.d.ts +90 -0
- package/dist/services/NodeService.d.ts.map +1 -0
- package/dist/services/NodeService.js +958 -0
- package/dist/services/NodeService.js.map +1 -0
- package/dist/services/OpenSpecParser.d.ts +43 -0
- package/dist/services/OpenSpecParser.d.ts.map +1 -0
- package/dist/services/OpenSpecParser.js +191 -0
- package/dist/services/OpenSpecParser.js.map +1 -0
- package/dist/services/ReferenceService.d.ts +35 -0
- package/dist/services/ReferenceService.d.ts.map +1 -0
- package/dist/services/ReferenceService.js +195 -0
- package/dist/services/ReferenceService.js.map +1 -0
- package/dist/services/RepairService.d.ts +36 -0
- package/dist/services/RepairService.d.ts.map +1 -0
- package/dist/services/RepairService.js +429 -0
- package/dist/services/RepairService.js.map +1 -0
- package/dist/services/SearchService.d.ts +34 -0
- package/dist/services/SearchService.d.ts.map +1 -0
- package/dist/services/SearchService.js +293 -0
- package/dist/services/SearchService.js.map +1 -0
- package/dist/services/SessionService.d.ts +136 -0
- package/dist/services/SessionService.d.ts.map +1 -0
- package/dist/services/SessionService.js +297 -0
- package/dist/services/SessionService.js.map +1 -0
- package/dist/services/StateService.d.ts +97 -0
- package/dist/services/StateService.d.ts.map +1 -0
- package/dist/services/StateService.js +846 -0
- package/dist/services/StateService.js.map +1 -0
- package/dist/services/TutorialService.d.ts +114 -0
- package/dist/services/TutorialService.d.ts.map +1 -0
- package/dist/services/TutorialService.js +1262 -0
- package/dist/services/TutorialService.js.map +1 -0
- package/dist/services/WorkspaceService.d.ts +273 -0
- package/dist/services/WorkspaceService.d.ts.map +1 -0
- package/dist/services/WorkspaceService.js +1764 -0
- package/dist/services/WorkspaceService.js.map +1 -0
- package/dist/services/index.d.ts +15 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +14 -0
- package/dist/services/index.js.map +1 -0
- package/dist/storage/FileSystemAdapter.d.ts +223 -0
- package/dist/storage/FileSystemAdapter.d.ts.map +1 -0
- package/dist/storage/FileSystemAdapter.js +384 -0
- package/dist/storage/FileSystemAdapter.js.map +1 -0
- package/dist/storage/JsonStorage.d.ts +158 -0
- package/dist/storage/JsonStorage.d.ts.map +1 -0
- package/dist/storage/JsonStorage.js +613 -0
- package/dist/storage/JsonStorage.js.map +1 -0
- package/dist/storage/MarkdownStorage.d.ts +178 -0
- package/dist/storage/MarkdownStorage.d.ts.map +1 -0
- package/dist/storage/MarkdownStorage.js +918 -0
- package/dist/storage/MarkdownStorage.js.map +1 -0
- package/dist/storage/SessionBindingStorage.d.ts +69 -0
- package/dist/storage/SessionBindingStorage.d.ts.map +1 -0
- package/dist/storage/SessionBindingStorage.js +131 -0
- package/dist/storage/SessionBindingStorage.js.map +1 -0
- package/dist/storage/index.d.ts +6 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +6 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/tools/capability.d.ts +18 -0
- package/dist/tools/capability.d.ts.map +1 -0
- package/dist/tools/capability.js +73 -0
- package/dist/tools/capability.js.map +1 -0
- package/dist/tools/config.d.ts +14 -0
- package/dist/tools/config.d.ts.map +1 -0
- package/dist/tools/config.js +61 -0
- package/dist/tools/config.js.map +1 -0
- package/dist/tools/context.d.ts +22 -0
- package/dist/tools/context.d.ts.map +1 -0
- package/dist/tools/context.js +139 -0
- package/dist/tools/context.js.map +1 -0
- package/dist/tools/dispatch.d.ts +41 -0
- package/dist/tools/dispatch.d.ts.map +1 -0
- package/dist/tools/dispatch.js +380 -0
- package/dist/tools/dispatch.js.map +1 -0
- package/dist/tools/help.d.ts +44 -0
- package/dist/tools/help.d.ts.map +1 -0
- package/dist/tools/help.js +227 -0
- package/dist/tools/help.js.map +1 -0
- package/dist/tools/import.d.ts +17 -0
- package/dist/tools/import.d.ts.map +1 -0
- package/dist/tools/import.js +96 -0
- package/dist/tools/import.js.map +1 -0
- package/dist/tools/index.d.ts +12 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +13 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/log.d.ts +21 -0
- package/dist/tools/log.d.ts.map +1 -0
- package/dist/tools/log.js +93 -0
- package/dist/tools/log.js.map +1 -0
- package/dist/tools/memo.d.ts +26 -0
- package/dist/tools/memo.d.ts.map +1 -0
- package/dist/tools/memo.js +188 -0
- package/dist/tools/memo.js.map +1 -0
- package/dist/tools/node.d.ts +34 -0
- package/dist/tools/node.d.ts.map +1 -0
- package/dist/tools/node.js +328 -0
- package/dist/tools/node.js.map +1 -0
- package/dist/tools/search.d.ts +14 -0
- package/dist/tools/search.d.ts.map +1 -0
- package/dist/tools/search.js +95 -0
- package/dist/tools/search.js.map +1 -0
- package/dist/tools/session.d.ts +22 -0
- package/dist/tools/session.d.ts.map +1 -0
- package/dist/tools/session.js +127 -0
- package/dist/tools/session.js.map +1 -0
- package/dist/tools/state.d.ts +10 -0
- package/dist/tools/state.d.ts.map +1 -0
- package/dist/tools/state.js +79 -0
- package/dist/tools/state.js.map +1 -0
- package/dist/tools/workspace.d.ts +38 -0
- package/dist/tools/workspace.d.ts.map +1 -0
- package/dist/tools/workspace.js +240 -0
- package/dist/tools/workspace.js.map +1 -0
- package/dist/types/capability.d.ts +36 -0
- package/dist/types/capability.d.ts.map +1 -0
- package/dist/types/capability.js +3 -0
- package/dist/types/capability.js.map +1 -0
- package/dist/types/confirmation.d.ts +35 -0
- package/dist/types/confirmation.d.ts.map +1 -0
- package/dist/types/confirmation.js +3 -0
- package/dist/types/confirmation.js.map +1 -0
- package/dist/types/context.d.ts +174 -0
- package/dist/types/context.d.ts.map +1 -0
- package/dist/types/context.js +3 -0
- package/dist/types/context.js.map +1 -0
- package/dist/types/errors.d.ts +81 -0
- package/dist/types/errors.d.ts.map +1 -0
- package/dist/types/errors.js +154 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/guidance.d.ts +162 -0
- package/dist/types/guidance.d.ts.map +1 -0
- package/dist/types/guidance.js +4 -0
- package/dist/types/guidance.js.map +1 -0
- package/dist/types/health.d.ts +61 -0
- package/dist/types/health.d.ts.map +1 -0
- package/dist/types/health.js +3 -0
- package/dist/types/health.js.map +1 -0
- package/dist/types/index.d.ts +10 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +11 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/memo.d.ts +132 -0
- package/dist/types/memo.d.ts.map +1 -0
- package/dist/types/memo.js +3 -0
- package/dist/types/memo.js.map +1 -0
- package/dist/types/node.d.ts +316 -0
- package/dist/types/node.d.ts.map +1 -0
- package/dist/types/node.js +3 -0
- package/dist/types/node.js.map +1 -0
- package/dist/types/repair.d.ts +62 -0
- package/dist/types/repair.d.ts.map +1 -0
- package/dist/types/repair.js +4 -0
- package/dist/types/repair.js.map +1 -0
- package/dist/types/search.d.ts +58 -0
- package/dist/types/search.d.ts.map +1 -0
- package/dist/types/search.js +3 -0
- package/dist/types/search.js.map +1 -0
- package/dist/types/settings.d.ts +109 -0
- package/dist/types/settings.d.ts.map +1 -0
- package/dist/types/settings.js +30 -0
- package/dist/types/settings.js.map +1 -0
- package/dist/types/workspace.d.ts +357 -0
- package/dist/types/workspace.d.ts.map +1 -0
- package/dist/types/workspace.js +3 -0
- package/dist/types/workspace.js.map +1 -0
- package/dist/utils/contentValidation.d.ts +47 -0
- package/dist/utils/contentValidation.d.ts.map +1 -0
- package/dist/utils/contentValidation.js +93 -0
- package/dist/utils/contentValidation.js.map +1 -0
- package/dist/utils/devLog.d.ts +43 -0
- package/dist/utils/devLog.d.ts.map +1 -0
- package/dist/utils/devLog.js +94 -0
- package/dist/utils/devLog.js.map +1 -0
- package/dist/utils/errorLogger.d.ts +27 -0
- package/dist/utils/errorLogger.d.ts.map +1 -0
- package/dist/utils/errorLogger.js +105 -0
- package/dist/utils/errorLogger.js.map +1 -0
- package/dist/utils/git.d.ts +123 -0
- package/dist/utils/git.d.ts.map +1 -0
- package/dist/utils/git.js +400 -0
- package/dist/utils/git.js.map +1 -0
- package/dist/utils/hash.d.ts +32 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +37 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/id.d.ts +54 -0
- package/dist/utils/id.d.ts.map +1 -0
- package/dist/utils/id.js +96 -0
- package/dist/utils/id.js.map +1 -0
- package/dist/utils/index.d.ts +8 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +9 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +42 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +228 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/manualChangeFormatter.d.ts +8 -0
- package/dist/utils/manualChangeFormatter.d.ts.map +1 -0
- package/dist/utils/manualChangeFormatter.js +21 -0
- package/dist/utils/manualChangeFormatter.js.map +1 -0
- package/dist/utils/paramValidator.d.ts +35 -0
- package/dist/utils/paramValidator.d.ts.map +1 -0
- package/dist/utils/paramValidator.js +214 -0
- package/dist/utils/paramValidator.js.map +1 -0
- package/dist/utils/port.d.ts +7 -0
- package/dist/utils/port.d.ts.map +1 -0
- package/dist/utils/port.js +28 -0
- package/dist/utils/port.js.map +1 -0
- package/dist/utils/processManager.d.ts +53 -0
- package/dist/utils/processManager.d.ts.map +1 -0
- package/dist/utils/processManager.js +267 -0
- package/dist/utils/processManager.js.map +1 -0
- package/dist/utils/sessionLogger.d.ts +28 -0
- package/dist/utils/sessionLogger.d.ts.map +1 -0
- package/dist/utils/sessionLogger.js +142 -0
- package/dist/utils/sessionLogger.js.map +1 -0
- package/dist/utils/time.d.ts +15 -0
- package/dist/utils/time.d.ts.map +1 -0
- package/dist/utils/time.js +32 -0
- package/dist/utils/time.js.map +1 -0
- package/dist/utils/validation.d.ts +23 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +88 -0
- package/dist/utils/validation.js.map +1 -0
- package/docs//346/227/245/345/277/227/347/263/273/347/273/237.md +389 -0
- package/docs//347/224/250/346/210/267/346/211/213/345/206/214.md +1446 -0
- package/docs//347/224/250/346/210/267/346/211/213/345/206/214/344/270/216/346/212/200/346/234/257/346/214/207/345/215/227.md +873 -0
- package/package.json +94 -0
- package/plugin/README.md +141 -0
- package/plugin/agents/zero-executor.md +114 -0
- package/plugin/agents/zero-reviewer.md +133 -0
- package/plugin/docs/diagnostic-guide.md +128 -0
- package/plugin/hooks/hooks.json.deprecated +70 -0
- package/plugin/scripts/cursor-hook-entry.cjs +217 -0
- package/plugin/scripts/hook-entry.cjs +663 -0
- package/plugin/scripts/openspec-import.cjs +714 -0
- package/plugin/scripts/shared/binding.cjs +98 -0
- package/plugin/scripts/shared/config.cjs +65 -0
- package/plugin/scripts/shared/context.cjs +120 -0
- package/plugin/scripts/shared/index.cjs +34 -0
- package/plugin/scripts/shared/logger.cjs +196 -0
- package/plugin/scripts/shared/reminder.cjs +261 -0
- package/plugin/scripts/shared/utils.cjs +62 -0
- package/plugin/scripts/shared/workspace.cjs +322 -0
- package/plugin/skills/aligning-intent/SKILL.md +275 -0
- package/plugin/skills/analyzing-measurements/SKILL.md +223 -0
- package/plugin/skills/bootstrapping-workspace/SKILL.md +260 -0
- package/plugin/skills/designing-solutions/SKILL.md +363 -0
- package/plugin/skills/diagnosing-issues/SKILL.md +219 -0
- package/plugin/skills/discovering-context/SKILL.md +283 -0
- package/plugin/skills/dispatching-parent/SKILL.md +399 -0
- package/plugin/skills/executing-task/SKILL.md +340 -0
- package/plugin/skills/memo-create/SKILL.md +222 -0
- package/plugin/skills/planning-verification/SKILL.md +245 -0
- package/plugin/skills/preparing-dispatch/SKILL.md +299 -0
- package/plugin/skills/researching-tech/SKILL.md +223 -0
- package/plugin/skills/reviewing-quality/SKILL.md +354 -0
- package/plugin/skills/reviewing-spec/SKILL.md +333 -0
- package/plugin/skills/starting-info-flow/SKILL.md +196 -0
- package/web/README.md +5 -0
- package/web/dist/assets/DocsView-Bls_Vjsr.css +1 -0
- package/web/dist/assets/DocsView-Cxc0B63r.js +1447 -0
- package/web/dist/assets/HomeView-C7df9thb.js +9 -0
- package/web/dist/assets/HomeView-ufUdnfHk.css +1 -0
- package/web/dist/assets/MarkdownContent-DXp6CtSP.js +308 -0
- package/web/dist/assets/MarkdownContent-NFqiOBLH.css +1 -0
- package/web/dist/assets/NotFoundView-BYX1oZAn.css +1 -0
- package/web/dist/assets/NotFoundView-zrc0lT9q.js +1 -0
- package/web/dist/assets/WorkspaceView-BckqgNcX.js +27 -0
- package/web/dist/assets/WorkspaceView-J1dgpYMx.css +1 -0
- package/web/dist/assets/WsConfirmDialog-C1CvL4my.css +1 -0
- package/web/dist/assets/WsConfirmDialog-gLEP7uBD.js +4 -0
- package/web/dist/assets/arc-DPkKTkUT.js +1 -0
- package/web/dist/assets/architectureDiagram-VXUJARFQ-CEGpqUlZ.js +36 -0
- package/web/dist/assets/blockDiagram-VD42YOAC-Bv-mqdQH.js +122 -0
- package/web/dist/assets/c4Diagram-YG6GDRKO-DRyPatZ_.js +10 -0
- package/web/dist/assets/channel-B84mKLDZ.js +1 -0
- package/web/dist/assets/chunk-4BX2VUAB-c7DivX0u.js +1 -0
- package/web/dist/assets/chunk-55IACEB6-CGKTaLlo.js +1 -0
- package/web/dist/assets/chunk-B4BG7PRW-Czhx5Q_P.js +165 -0
- package/web/dist/assets/chunk-DI55MBZ5-CQVA7hcZ.js +220 -0
- package/web/dist/assets/chunk-FMBD7UC4-hEiPmi7V.js +15 -0
- package/web/dist/assets/chunk-QN33PNHL-rL6yYI-E.js +1 -0
- package/web/dist/assets/chunk-QZHKN3VN-BRyHBBzq.js +1 -0
- package/web/dist/assets/chunk-TZMSLE5B-D4PXmTz9.js +1 -0
- package/web/dist/assets/classDiagram-2ON5EDUG-CNn53ohi.js +1 -0
- package/web/dist/assets/classDiagram-v2-WZHVMYZB-CNn53ohi.js +1 -0
- package/web/dist/assets/cose-bilkent-S5V4N54A-BAREnRga.js +1 -0
- package/web/dist/assets/cytoscape.esm-BnkdMOzK.js +321 -0
- package/web/dist/assets/dagre-6UL2VRFP-DaYzb3MT.js +4 -0
- package/web/dist/assets/defaultLocale-C4B-KCzX.js +1 -0
- package/web/dist/assets/diagram-PSM6KHXK-BFltDqvd.js +24 -0
- package/web/dist/assets/diagram-QEK2KX5R-CR4VU2La.js +43 -0
- package/web/dist/assets/diagram-S2PKOQOG-0UfIeT-1.js +24 -0
- package/web/dist/assets/erDiagram-Q2GNP2WA-Bo17Xmng.js +60 -0
- package/web/dist/assets/flowDiagram-NV44I4VS-CzqhQp8s.js +162 -0
- package/web/dist/assets/ganttDiagram-JELNMOA3-TXwXtUcq.js +267 -0
- package/web/dist/assets/gitGraphDiagram-NY62KEGX-CoFQTy9O.js +65 -0
- package/web/dist/assets/graph-CIQcRIVd.js +1 -0
- package/web/dist/assets/index-BgLd_o_M.css +1 -0
- package/web/dist/assets/index-Cd_J3fZn.js +30 -0
- package/web/dist/assets/infoDiagram-WHAUD3N6-Dq0xXfVu.js +2 -0
- package/web/dist/assets/init-Gi6I4Gst.js +1 -0
- package/web/dist/assets/journeyDiagram-XKPGCS4Q-jIg5BOfC.js +139 -0
- package/web/dist/assets/kanban-definition-3W4ZIXB7-D2giu6aZ.js +89 -0
- package/web/dist/assets/katex-XbL3y5x-.js +261 -0
- package/web/dist/assets/layout-Bm-XCM-8.js +1 -0
- package/web/dist/assets/linear-FbekP9OZ.js +1 -0
- package/web/dist/assets/min-BrRCpYmF.js +1 -0
- package/web/dist/assets/mindmap-definition-VGOIOE7T-o-4ubbY9.js +68 -0
- package/web/dist/assets/noto-emoji-0-400-normal-BTQbhB77.woff +0 -0
- package/web/dist/assets/noto-emoji-0-400-normal-DHdy6Uhy.woff2 +0 -0
- package/web/dist/assets/noto-emoji-1-400-normal-0IvkdXBB.woff +0 -0
- package/web/dist/assets/noto-emoji-1-400-normal-BY9OovbM.woff2 +0 -0
- package/web/dist/assets/noto-emoji-10-400-normal-D9w4QCof.woff2 +0 -0
- package/web/dist/assets/noto-emoji-10-400-normal-DtCumcZR.woff +0 -0
- package/web/dist/assets/noto-emoji-11-400-normal-BboTlyvx.woff +0 -0
- package/web/dist/assets/noto-emoji-12-400-normal-BB5pgBKj.woff2 +0 -0
- package/web/dist/assets/noto-emoji-12-400-normal-g186qhiA.woff +0 -0
- package/web/dist/assets/noto-emoji-2-400-normal-BKCR1azW.woff2 +0 -0
- package/web/dist/assets/noto-emoji-2-400-normal-BYH0KhDr.woff +0 -0
- package/web/dist/assets/noto-emoji-3-400-normal-CnPTUeEK.woff +0 -0
- package/web/dist/assets/noto-emoji-3-400-normal-TrTb2VQM.woff2 +0 -0
- package/web/dist/assets/noto-emoji-4-400-normal-BxD0KVdj.woff +0 -0
- package/web/dist/assets/noto-emoji-4-400-normal-s_n9EyG1.woff2 +0 -0
- package/web/dist/assets/noto-emoji-5-400-normal-C190AIxR.woff +0 -0
- package/web/dist/assets/noto-emoji-5-400-normal-Ctfx4xc6.woff2 +0 -0
- package/web/dist/assets/noto-emoji-6-400-normal-DlXlXWt7.woff +0 -0
- package/web/dist/assets/noto-emoji-6-400-normal-NzsjD754.woff2 +0 -0
- package/web/dist/assets/noto-emoji-7-400-normal-BHP8KeA6.woff2 +0 -0
- package/web/dist/assets/noto-emoji-7-400-normal-CtuKhtAZ.woff +0 -0
- package/web/dist/assets/noto-emoji-8-400-normal-DR49ZFe7.woff +0 -0
- package/web/dist/assets/noto-emoji-8-400-normal-Dvmkf6b2.woff2 +0 -0
- package/web/dist/assets/noto-emoji-9-400-normal-BeHJQ2iK.woff2 +0 -0
- package/web/dist/assets/noto-emoji-9-400-normal-BlXmCgeQ.woff +0 -0
- package/web/dist/assets/ordinal-Cboi1Yqb.js +1 -0
- package/web/dist/assets/pieDiagram-ADFJNKIX-C45wSpld.js +30 -0
- package/web/dist/assets/quadrantDiagram-AYHSOK5B-tv-_fe-W.js +7 -0
- package/web/dist/assets/reduce-CoLNNlNb.js +1 -0
- package/web/dist/assets/requirementDiagram-UZGBJVZJ-Dn6PDfkL.js +64 -0
- package/web/dist/assets/sankeyDiagram-TZEHDZUN-CbXTZAsG.js +10 -0
- package/web/dist/assets/sequenceDiagram-WL72ISMW-B-o1CUJ5.js +145 -0
- package/web/dist/assets/stateDiagram-FKZM4ZOC-hzrupXQi.js +1 -0
- package/web/dist/assets/stateDiagram-v2-4FDKWEC3-DN-c2M96.js +1 -0
- package/web/dist/assets/timeline-definition-IT6M3QCI-R5SP9GDo.js +61 -0
- package/web/dist/assets/treemap-KMMF4GRG-Pg9KlUOt.js +128 -0
- package/web/dist/assets/xychartDiagram-PRI3JC2R-C3vbJhd1.js +7 -0
- package/web/dist/favicon.svg +13 -0
- package/web/dist/index.html +17 -0
- package//351/205/215/347/275/256/346/226/271/345/274/217.md +330 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
export interface PidInfo {
|
|
2
|
+
pid: number;
|
|
3
|
+
port: number;
|
|
4
|
+
version: string;
|
|
5
|
+
startedAt: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* 获取 PID 文件路径
|
|
9
|
+
*/
|
|
10
|
+
export declare function getPidFilePath(): string;
|
|
11
|
+
/**
|
|
12
|
+
* 读取 PID 信息
|
|
13
|
+
*/
|
|
14
|
+
export declare function readPidInfo(): PidInfo | null;
|
|
15
|
+
/**
|
|
16
|
+
* 写入 PID 信息
|
|
17
|
+
*/
|
|
18
|
+
export declare function writePidInfo(info: PidInfo): void;
|
|
19
|
+
/**
|
|
20
|
+
* 删除 PID 文件
|
|
21
|
+
*/
|
|
22
|
+
export declare function removePidFile(): void;
|
|
23
|
+
/**
|
|
24
|
+
* 检查进程是否存活
|
|
25
|
+
*/
|
|
26
|
+
export declare function isProcessRunning(pid: number): boolean;
|
|
27
|
+
/**
|
|
28
|
+
* 检查端口占用并获取占用进程的 PID
|
|
29
|
+
*/
|
|
30
|
+
export declare function getPortProcess(port: number): number | null;
|
|
31
|
+
/**
|
|
32
|
+
* 终止进程
|
|
33
|
+
*/
|
|
34
|
+
export declare function killProcess(pid: number): boolean;
|
|
35
|
+
/**
|
|
36
|
+
* 检查进程命令行是否包含指定关键词
|
|
37
|
+
*/
|
|
38
|
+
export declare function getProcessCommand(pid: number): string | null;
|
|
39
|
+
/**
|
|
40
|
+
* 检查并清理旧版本端口上的进程
|
|
41
|
+
* @param logger 日志函数
|
|
42
|
+
* @returns 是否执行了迁移
|
|
43
|
+
*/
|
|
44
|
+
export declare function migrateLegacyPorts(logger?: (msg: string) => void): boolean;
|
|
45
|
+
/**
|
|
46
|
+
* 检查并处理旧版本进程
|
|
47
|
+
* @param port 要使用的端口
|
|
48
|
+
* @param currentVersion 当前版本
|
|
49
|
+
* @param logger 日志函数
|
|
50
|
+
* @returns true 表示可以继续启动,false 表示应该跳过(相同版本已在运行)
|
|
51
|
+
*/
|
|
52
|
+
export declare function handleOldProcess(port: number, currentVersion: string, logger?: (msg: string) => void): boolean;
|
|
53
|
+
//# sourceMappingURL=processManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processManager.d.ts","sourceRoot":"","sources":["../../src/utils/processManager.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,OAAO;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED;;GAEG;AACH,wBAAgB,WAAW,IAAI,OAAO,GAAG,IAAI,CAW5C;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAOhD;AAED;;GAEG;AACH,wBAAgB,aAAa,IAAI,IAAI,CASpC;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAOrD;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAwB1D;AAaD;;GAEG;AACH,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CA0BhD;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAe5D;AAOD;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,GAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAoB,GAAG,OAAO,CA4BzF;AAED;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,MAAM,EACZ,cAAc,EAAE,MAAM,EACtB,MAAM,GAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAoB,GAC5C,OAAO,CA6DT"}
|
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
// src/utils/processManager.ts
|
|
2
|
+
// 进程管理工具 - 版本检测和旧进程替换
|
|
3
|
+
import { execSync } from "child_process";
|
|
4
|
+
import * as fs from "fs";
|
|
5
|
+
import * as path from "path";
|
|
6
|
+
import * as os from "os";
|
|
7
|
+
const IS_DEV = process.env.NODE_ENV === "development" || process.env.ZERO_DEV === "true";
|
|
8
|
+
const baseDir = IS_DEV ? ".zero-workspace-dev" : ".zero-workspace";
|
|
9
|
+
/**
|
|
10
|
+
* 获取 PID 文件路径
|
|
11
|
+
*/
|
|
12
|
+
export function getPidFilePath() {
|
|
13
|
+
return path.join(os.homedir(), baseDir, "webui.pid");
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* 读取 PID 信息
|
|
17
|
+
*/
|
|
18
|
+
export function readPidInfo() {
|
|
19
|
+
try {
|
|
20
|
+
const pidFile = getPidFilePath();
|
|
21
|
+
if (fs.existsSync(pidFile)) {
|
|
22
|
+
const content = fs.readFileSync(pidFile, "utf-8");
|
|
23
|
+
return JSON.parse(content);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
catch {
|
|
27
|
+
// 忽略
|
|
28
|
+
}
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* 写入 PID 信息
|
|
33
|
+
*/
|
|
34
|
+
export function writePidInfo(info) {
|
|
35
|
+
const pidFile = getPidFilePath();
|
|
36
|
+
const dir = path.dirname(pidFile);
|
|
37
|
+
if (!fs.existsSync(dir)) {
|
|
38
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
39
|
+
}
|
|
40
|
+
fs.writeFileSync(pidFile, JSON.stringify(info, null, 2));
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* 删除 PID 文件
|
|
44
|
+
*/
|
|
45
|
+
export function removePidFile() {
|
|
46
|
+
try {
|
|
47
|
+
const pidFile = getPidFilePath();
|
|
48
|
+
if (fs.existsSync(pidFile)) {
|
|
49
|
+
fs.unlinkSync(pidFile);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
// 忽略
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* 检查进程是否存活
|
|
58
|
+
*/
|
|
59
|
+
export function isProcessRunning(pid) {
|
|
60
|
+
try {
|
|
61
|
+
process.kill(pid, 0);
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* 检查端口占用并获取占用进程的 PID
|
|
70
|
+
*/
|
|
71
|
+
export function getPortProcess(port) {
|
|
72
|
+
try {
|
|
73
|
+
if (process.platform === "win32") {
|
|
74
|
+
// Windows: netstat -ano | findstr :PORT
|
|
75
|
+
const result = execSync(`netstat -ano | findstr :${port}`, { encoding: "utf-8" });
|
|
76
|
+
const lines = result.trim().split("\n").filter(Boolean);
|
|
77
|
+
for (const line of lines) {
|
|
78
|
+
// 匹配 LISTENING 状态的行
|
|
79
|
+
if (line.includes("LISTENING")) {
|
|
80
|
+
const parts = line.trim().split(/\s+/);
|
|
81
|
+
const pid = parseInt(parts[parts.length - 1], 10);
|
|
82
|
+
if (!isNaN(pid))
|
|
83
|
+
return pid;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
// Unix: lsof
|
|
90
|
+
const result = execSync(`lsof -ti:${port} 2>/dev/null || true`, { encoding: "utf-8" });
|
|
91
|
+
const pids = result.trim().split("\n").filter(Boolean);
|
|
92
|
+
return pids.length > 0 ? parseInt(pids[0], 10) : null;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
catch {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* 跨平台等待
|
|
101
|
+
*/
|
|
102
|
+
function sleep(ms) {
|
|
103
|
+
if (process.platform === "win32") {
|
|
104
|
+
execSync(`ping -n 1 127.0.0.1 > nul`, { timeout: ms + 1000 });
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
execSync(`sleep ${ms / 1000}`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* 终止进程
|
|
112
|
+
*/
|
|
113
|
+
export function killProcess(pid) {
|
|
114
|
+
try {
|
|
115
|
+
if (process.platform === "win32") {
|
|
116
|
+
// Windows: taskkill
|
|
117
|
+
execSync(`taskkill /PID ${pid} /F 2>nul`, { encoding: "utf-8" });
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
process.kill(pid, "SIGTERM");
|
|
121
|
+
}
|
|
122
|
+
// 等待进程终止
|
|
123
|
+
let attempts = 0;
|
|
124
|
+
while (isProcessRunning(pid) && attempts < 10) {
|
|
125
|
+
sleep(100);
|
|
126
|
+
attempts++;
|
|
127
|
+
}
|
|
128
|
+
// 如果还在运行,强制终止
|
|
129
|
+
if (isProcessRunning(pid)) {
|
|
130
|
+
if (process.platform === "win32") {
|
|
131
|
+
execSync(`taskkill /PID ${pid} /F 2>nul`, { encoding: "utf-8" });
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
process.kill(pid, "SIGKILL");
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
return !isProcessRunning(pid);
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
return false;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* 检查进程命令行是否包含指定关键词
|
|
145
|
+
*/
|
|
146
|
+
export function getProcessCommand(pid) {
|
|
147
|
+
try {
|
|
148
|
+
if (process.platform === "win32") {
|
|
149
|
+
// Windows: wmic
|
|
150
|
+
const result = execSync(`wmic process where processid=${pid} get commandline 2>nul`, {
|
|
151
|
+
encoding: "utf-8",
|
|
152
|
+
});
|
|
153
|
+
const lines = result.trim().split("\n").filter(Boolean);
|
|
154
|
+
return lines.length > 1 ? lines[1].trim() : null;
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
return execSync(`ps -p ${pid} -o command= 2>/dev/null || true`, { encoding: "utf-8" }).trim();
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
catch {
|
|
161
|
+
return null;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* 旧版本使用的端口(用于迁移检测)
|
|
166
|
+
*/
|
|
167
|
+
const LEGACY_PORTS = [3000, 3001];
|
|
168
|
+
/**
|
|
169
|
+
* 检查并清理旧版本端口上的进程
|
|
170
|
+
* @param logger 日志函数
|
|
171
|
+
* @returns 是否执行了迁移
|
|
172
|
+
*/
|
|
173
|
+
export function migrateLegacyPorts(logger = console.error) {
|
|
174
|
+
let migrated = false;
|
|
175
|
+
for (const legacyPort of LEGACY_PORTS) {
|
|
176
|
+
const portPid = getPortProcess(legacyPort);
|
|
177
|
+
if (portPid) {
|
|
178
|
+
const cmdline = getProcessCommand(portPid);
|
|
179
|
+
// 检查是否是 zero-workspace 相关进程
|
|
180
|
+
if (cmdline && (cmdline.includes("zero-workspace") || cmdline.includes("dist/http") || cmdline.includes("dist/index"))) {
|
|
181
|
+
logger(`[迁移] 检测到旧版本服务在端口 ${legacyPort} 运行 (PID: ${portPid})`);
|
|
182
|
+
logger(`[迁移] 端口已从 ${legacyPort} 迁移到 19540/19541`);
|
|
183
|
+
logger(`[迁移] 正在关闭旧服务...`);
|
|
184
|
+
if (killProcess(portPid)) {
|
|
185
|
+
logger(`[迁移] 旧服务已关闭`);
|
|
186
|
+
migrated = true;
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
logger(`[迁移] 无法关闭旧服务,请手动关闭后重试`);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
if (migrated) {
|
|
195
|
+
logger(`[迁移] 提示:新版本 WebUI 地址为 http://localhost:19540`);
|
|
196
|
+
logger(`[迁移] 请更新浏览器书签`);
|
|
197
|
+
}
|
|
198
|
+
return migrated;
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* 检查并处理旧版本进程
|
|
202
|
+
* @param port 要使用的端口
|
|
203
|
+
* @param currentVersion 当前版本
|
|
204
|
+
* @param logger 日志函数
|
|
205
|
+
* @returns true 表示可以继续启动,false 表示应该跳过(相同版本已在运行)
|
|
206
|
+
*/
|
|
207
|
+
export function handleOldProcess(port, currentVersion, logger = console.error) {
|
|
208
|
+
// 首先检查并迁移旧版本端口
|
|
209
|
+
migrateLegacyPorts(logger);
|
|
210
|
+
const pidInfo = readPidInfo();
|
|
211
|
+
// 情况1:有 PID 记录且进程存活
|
|
212
|
+
if (pidInfo && isProcessRunning(pidInfo.pid)) {
|
|
213
|
+
// 检查端口是否匹配
|
|
214
|
+
const samePort = pidInfo.port === port;
|
|
215
|
+
if (pidInfo.version !== currentVersion) {
|
|
216
|
+
// 版本不同,需要替换
|
|
217
|
+
logger(`检测到旧版本进程 (v${pidInfo.version} → v${currentVersion})`);
|
|
218
|
+
logger(`正在终止旧进程 (PID: ${pidInfo.pid})...`);
|
|
219
|
+
if (killProcess(pidInfo.pid)) {
|
|
220
|
+
logger(`旧进程已终止`);
|
|
221
|
+
removePidFile();
|
|
222
|
+
return true;
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
const killCmd = process.platform === "win32" ? `taskkill /PID ${pidInfo.pid} /F` : `kill ${pidInfo.pid}`;
|
|
226
|
+
logger(`无法终止旧进程,请手动执行: ${killCmd}`);
|
|
227
|
+
return false;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
else if (samePort) {
|
|
231
|
+
// 相同版本且相同端口,跳过启动
|
|
232
|
+
logger(`服务已在运行 (PID: ${pidInfo.pid}, 端口: ${pidInfo.port}, 版本: ${pidInfo.version})`);
|
|
233
|
+
return false;
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
// 相同版本但不同端口,允许启动(旧进程在不同端口运行)
|
|
237
|
+
logger(`注意: 旧进程在端口 ${pidInfo.port} 运行,当前请求端口 ${port}`);
|
|
238
|
+
// 继续检查当前端口是否被占用
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
// 清理无效的 PID 记录
|
|
242
|
+
if (pidInfo && !isProcessRunning(pidInfo.pid)) {
|
|
243
|
+
removePidFile();
|
|
244
|
+
}
|
|
245
|
+
// 情况2:端口被占用
|
|
246
|
+
const portPid = getPortProcess(port);
|
|
247
|
+
if (portPid) {
|
|
248
|
+
const cmdline = getProcessCommand(portPid);
|
|
249
|
+
// 检查是否是 zero-workspace 相关进程
|
|
250
|
+
if (cmdline && (cmdline.includes("zero-workspace") || cmdline.includes("dist/http"))) {
|
|
251
|
+
logger(`端口 ${port} 被旧进程占用 (PID: ${portPid})`);
|
|
252
|
+
logger(`正在终止...`);
|
|
253
|
+
if (killProcess(portPid)) {
|
|
254
|
+
logger(`进程已终止`);
|
|
255
|
+
return true;
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
logger(`无法终止进程`);
|
|
259
|
+
return false;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// 其他进程占用端口,返回 false 但不报错(由调用方处理)
|
|
263
|
+
return false;
|
|
264
|
+
}
|
|
265
|
+
return true;
|
|
266
|
+
}
|
|
267
|
+
//# sourceMappingURL=processManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processManager.js","sourceRoot":"","sources":["../../src/utils/processManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 设置当前会话 ID
|
|
3
|
+
*/
|
|
4
|
+
export declare function setCurrentSessionId(sessionId: string | undefined): void;
|
|
5
|
+
/**
|
|
6
|
+
* 获取当前会话 ID
|
|
7
|
+
*/
|
|
8
|
+
export declare function getCurrentSessionId(): string | undefined;
|
|
9
|
+
/**
|
|
10
|
+
* 记录 MCP 工具调用开始
|
|
11
|
+
*/
|
|
12
|
+
export declare function logMcpStart(toolName: string, params?: Record<string, unknown>): void;
|
|
13
|
+
/**
|
|
14
|
+
* 记录 MCP 工具调用结束
|
|
15
|
+
*/
|
|
16
|
+
export declare function logMcpEnd(toolName: string, success: boolean, result: unknown, durationMs?: number): void;
|
|
17
|
+
/**
|
|
18
|
+
* 记录错误
|
|
19
|
+
*/
|
|
20
|
+
export declare function logMcpError(toolName: string, error: Error | string): void;
|
|
21
|
+
export declare const sessionLogger: {
|
|
22
|
+
setCurrentSessionId: typeof setCurrentSessionId;
|
|
23
|
+
getCurrentSessionId: typeof getCurrentSessionId;
|
|
24
|
+
logMcpStart: typeof logMcpStart;
|
|
25
|
+
logMcpEnd: typeof logMcpEnd;
|
|
26
|
+
logMcpError: typeof logMcpError;
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=sessionLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessionLogger.d.ts","sourceRoot":"","sources":["../../src/utils/sessionLogger.ts"],"names":[],"mappings":"AAgDA;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAEvE;AAED;;GAEG;AACH,wBAAgB,mBAAmB,IAAI,MAAM,GAAG,SAAS,CAExD;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,GAAG,IAAI,CAmBxF;AAED;;GAEG;AACH,wBAAgB,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,GAAE,MAAU,GAAG,IAAI,CA2B3G;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,IAAI,CAoBzE;AAED,eAAO,MAAM,aAAa;;;;;;CAMzB,CAAC"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
// src/utils/sessionLogger.ts
|
|
2
|
+
// 会话级别日志记录器
|
|
3
|
+
// - 有 sessionId:写入 {sessionId}.log
|
|
4
|
+
// - 无 sessionId:写入 system.log
|
|
5
|
+
import * as fs from "node:fs";
|
|
6
|
+
import * as path from "node:path";
|
|
7
|
+
import * as os from "node:os";
|
|
8
|
+
import { logger } from "./logger.js";
|
|
9
|
+
const IS_DEV = process.env.NODE_ENV === "development" || process.env.ZERO_DEV === "true";
|
|
10
|
+
const DIR_SUFFIX = IS_DEV ? "-dev" : "";
|
|
11
|
+
const ZERO_HOME = path.join(os.homedir(), `.zero-workspace${DIR_SUFFIX}`);
|
|
12
|
+
const LOGS_DIR = path.join(ZERO_HOME, "logs");
|
|
13
|
+
// 当前活跃的 sessionId(从 session_bind/session_status 调用中提取)
|
|
14
|
+
let currentSessionId;
|
|
15
|
+
/**
|
|
16
|
+
* 确保日志目录存在
|
|
17
|
+
*/
|
|
18
|
+
function ensureLogsDir() {
|
|
19
|
+
try {
|
|
20
|
+
if (!fs.existsSync(LOGS_DIR)) {
|
|
21
|
+
fs.mkdirSync(LOGS_DIR, { recursive: true });
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
catch {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* 写入会话专属日志
|
|
31
|
+
*/
|
|
32
|
+
function writeToSessionLog(sessionId, type, event, data) {
|
|
33
|
+
if (!ensureLogsDir())
|
|
34
|
+
return;
|
|
35
|
+
try {
|
|
36
|
+
const logPath = path.join(LOGS_DIR, `${sessionId}.log`);
|
|
37
|
+
const timestamp = new Date().toISOString();
|
|
38
|
+
const line = `[${timestamp}] [${type}] ${event}: ${JSON.stringify(data)}\n`;
|
|
39
|
+
fs.appendFileSync(logPath, line, "utf-8");
|
|
40
|
+
}
|
|
41
|
+
catch {
|
|
42
|
+
// 静默失败
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 设置当前会话 ID
|
|
47
|
+
*/
|
|
48
|
+
export function setCurrentSessionId(sessionId) {
|
|
49
|
+
currentSessionId = sessionId;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* 获取当前会话 ID
|
|
53
|
+
*/
|
|
54
|
+
export function getCurrentSessionId() {
|
|
55
|
+
return currentSessionId;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* 记录 MCP 工具调用开始
|
|
59
|
+
*/
|
|
60
|
+
export function logMcpStart(toolName, params = {}) {
|
|
61
|
+
// 尝试从参数中提取 sessionId
|
|
62
|
+
if (params.sessionId && typeof params.sessionId === "string") {
|
|
63
|
+
currentSessionId = params.sessionId;
|
|
64
|
+
}
|
|
65
|
+
const data = {
|
|
66
|
+
event: "start",
|
|
67
|
+
tool: toolName,
|
|
68
|
+
params,
|
|
69
|
+
};
|
|
70
|
+
if (currentSessionId) {
|
|
71
|
+
// 有 sessionId:写入会话日志
|
|
72
|
+
writeToSessionLog(currentSessionId, "MCP", `${toolName}:start`, { params });
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// 无 sessionId:写入 system.log
|
|
76
|
+
logger.info("mcp", { ...data, sessionId: undefined });
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 记录 MCP 工具调用结束
|
|
81
|
+
*/
|
|
82
|
+
export function logMcpEnd(toolName, success, result, durationMs = 0) {
|
|
83
|
+
const resultStr = typeof result === "object" ? JSON.stringify(result) : String(result);
|
|
84
|
+
const truncatedResult = resultStr.length > 500 ? resultStr.slice(0, 500) + "..." : resultStr;
|
|
85
|
+
if (currentSessionId) {
|
|
86
|
+
// 有 sessionId:写入会话日志
|
|
87
|
+
writeToSessionLog(currentSessionId, "MCP", `${toolName}:end`, {
|
|
88
|
+
success,
|
|
89
|
+
result: truncatedResult,
|
|
90
|
+
durationMs,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
// 无 sessionId:写入 system.log
|
|
95
|
+
const data = {
|
|
96
|
+
event: "end",
|
|
97
|
+
tool: toolName,
|
|
98
|
+
sessionId: undefined,
|
|
99
|
+
success,
|
|
100
|
+
result: truncatedResult,
|
|
101
|
+
durationMs,
|
|
102
|
+
};
|
|
103
|
+
if (success) {
|
|
104
|
+
logger.info("mcp", data);
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
logger.error("mcp", data);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* 记录错误
|
|
113
|
+
*/
|
|
114
|
+
export function logMcpError(toolName, error) {
|
|
115
|
+
const errorMsg = error instanceof Error ? error.message : String(error);
|
|
116
|
+
const errorStack = error instanceof Error ? error.stack : undefined;
|
|
117
|
+
if (currentSessionId) {
|
|
118
|
+
// 有 sessionId:写入会话日志
|
|
119
|
+
writeToSessionLog(currentSessionId, "MCP", `${toolName}:error`, {
|
|
120
|
+
error: errorMsg,
|
|
121
|
+
stack: errorStack,
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
// 无 sessionId:写入 system.log
|
|
126
|
+
logger.error("mcp", {
|
|
127
|
+
event: "error",
|
|
128
|
+
tool: toolName,
|
|
129
|
+
sessionId: undefined,
|
|
130
|
+
error: errorMsg,
|
|
131
|
+
stack: errorStack,
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
export const sessionLogger = {
|
|
136
|
+
setCurrentSessionId,
|
|
137
|
+
getCurrentSessionId,
|
|
138
|
+
logMcpStart,
|
|
139
|
+
logMcpEnd,
|
|
140
|
+
logMcpError,
|
|
141
|
+
};
|
|
142
|
+
//# sourceMappingURL=sessionLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessionLogger.js","sourceRoot":"","sources":["../../src/utils/sessionLogger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 获取当前时间的 ISO 8601 格式字符串
|
|
3
|
+
*/
|
|
4
|
+
export declare function now(): string;
|
|
5
|
+
/**
|
|
6
|
+
* 格式化时间为简短格式 (用于日志显示)
|
|
7
|
+
* 例如: "2024-01-15 14:30:25"
|
|
8
|
+
*/
|
|
9
|
+
export declare function formatShort(isoString: string): string;
|
|
10
|
+
/**
|
|
11
|
+
* 格式化时间为 HH:mm 格式 (用于日志记录)
|
|
12
|
+
* 例如: "14:30"
|
|
13
|
+
*/
|
|
14
|
+
export declare function formatHHmm(isoString?: string): string;
|
|
15
|
+
//# sourceMappingURL=time.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"time.d.ts","sourceRoot":"","sources":["../../src/utils/time.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,wBAAgB,GAAG,IAAI,MAAM,CAE5B;AAED;;;GAGG;AACH,wBAAgB,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CASrD;AAED;;;GAGG;AACH,wBAAgB,UAAU,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAKrD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
// src/utils/time.ts
|
|
2
|
+
/**
|
|
3
|
+
* 获取当前时间的 ISO 8601 格式字符串
|
|
4
|
+
*/
|
|
5
|
+
export function now() {
|
|
6
|
+
return new Date().toISOString();
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* 格式化时间为简短格式 (用于日志显示)
|
|
10
|
+
* 例如: "2024-01-15 14:30:25"
|
|
11
|
+
*/
|
|
12
|
+
export function formatShort(isoString) {
|
|
13
|
+
const date = new Date(isoString);
|
|
14
|
+
const year = date.getFullYear();
|
|
15
|
+
const month = String(date.getMonth() + 1).padStart(2, "0");
|
|
16
|
+
const day = String(date.getDate()).padStart(2, "0");
|
|
17
|
+
const hours = String(date.getHours()).padStart(2, "0");
|
|
18
|
+
const minutes = String(date.getMinutes()).padStart(2, "0");
|
|
19
|
+
const seconds = String(date.getSeconds()).padStart(2, "0");
|
|
20
|
+
return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* 格式化时间为 HH:mm 格式 (用于日志记录)
|
|
24
|
+
* 例如: "14:30"
|
|
25
|
+
*/
|
|
26
|
+
export function formatHHmm(isoString) {
|
|
27
|
+
const date = isoString ? new Date(isoString) : new Date();
|
|
28
|
+
const hours = String(date.getHours()).padStart(2, "0");
|
|
29
|
+
const minutes = String(date.getMinutes()).padStart(2, "0");
|
|
30
|
+
return `${hours}:${minutes}`;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=time.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"time.js","sourceRoot":"","sources":["../../src/utils/time.ts"],"names":[],"mappings":"AAAA,oBAAoB;AAEpB;;GAEG;AACH,MAAM,UAAU,GAAG;IACjB,OAAO,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AAClC,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,WAAW,CAAC,SAAiB;IAC3C,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;IACjC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IAChC,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACpD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3D,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3D,OAAO,GAAG,IAAI,IAAI,KAAK,IAAI,GAAG,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;AAClE,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,UAAU,CAAC,SAAkB;IAC3C,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;IAC1D,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3D,OAAO,GAAG,KAAK,IAAI,OAAO,EAAE,CAAC;AAC/B,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 验证工作区名称
|
|
3
|
+
* @throws ZeroError 如果名称不合法
|
|
4
|
+
*/
|
|
5
|
+
export declare function validateWorkspaceName(name: string): void;
|
|
6
|
+
/**
|
|
7
|
+
* 验证节点标题
|
|
8
|
+
* @throws ZeroError 如果标题不合法
|
|
9
|
+
*/
|
|
10
|
+
export declare function validateNodeTitle(title: string): void;
|
|
11
|
+
/**
|
|
12
|
+
* 验证 ID 是否为空
|
|
13
|
+
*/
|
|
14
|
+
export declare function validateId(id: string | undefined | null, type: "workspace" | "node"): void;
|
|
15
|
+
/**
|
|
16
|
+
* 验证并规范化项目根目录路径
|
|
17
|
+
* @param inputPath 用户输入的路径
|
|
18
|
+
* @param basePath 基准路径(默认为 cwd),用于解析相对路径
|
|
19
|
+
* @returns 规范化后的绝对路径
|
|
20
|
+
* @throws ZeroError 如果路径不安全或不存在
|
|
21
|
+
*/
|
|
22
|
+
export declare function validateProjectRoot(inputPath: string, basePath?: string): string;
|
|
23
|
+
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"AAWA;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAOxD;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAOrD;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE,WAAW,GAAG,MAAM,GAAG,IAAI,CAQ1F;AAED;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAsB,GAAG,MAAM,CAyC/F"}
|