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,88 @@
|
|
|
1
|
+
// src/utils/validation.ts
|
|
2
|
+
import * as path from "node:path";
|
|
3
|
+
import * as fs from "node:fs";
|
|
4
|
+
import { ZeroError } from "../types/errors.js";
|
|
5
|
+
/**
|
|
6
|
+
* 禁止在名称中使用的字符
|
|
7
|
+
*/
|
|
8
|
+
const INVALID_CHARS = /[/\\:*?"<>|]/;
|
|
9
|
+
/**
|
|
10
|
+
* 验证工作区名称
|
|
11
|
+
* @throws ZeroError 如果名称不合法
|
|
12
|
+
*/
|
|
13
|
+
export function validateWorkspaceName(name) {
|
|
14
|
+
if (!name || name.trim().length === 0) {
|
|
15
|
+
throw new ZeroError("INVALID_NAME", "工作区名称不能为空");
|
|
16
|
+
}
|
|
17
|
+
if (INVALID_CHARS.test(name)) {
|
|
18
|
+
throw new ZeroError("INVALID_NAME", "工作区名称不能包含特殊字符: / \\ : * ? \" < > |");
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* 验证节点标题
|
|
23
|
+
* @throws ZeroError 如果标题不合法
|
|
24
|
+
*/
|
|
25
|
+
export function validateNodeTitle(title) {
|
|
26
|
+
if (!title || title.trim().length === 0) {
|
|
27
|
+
throw new ZeroError("INVALID_TITLE", "节点标题不能为空");
|
|
28
|
+
}
|
|
29
|
+
if (INVALID_CHARS.test(title)) {
|
|
30
|
+
throw new ZeroError("INVALID_TITLE", "节点标题不能包含特殊字符: / \\ : * ? \" < > |");
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* 验证 ID 是否为空
|
|
35
|
+
*/
|
|
36
|
+
export function validateId(id, type) {
|
|
37
|
+
if (!id || id.trim().length === 0) {
|
|
38
|
+
if (type === "workspace") {
|
|
39
|
+
throw new ZeroError("WORKSPACE_NOT_FOUND", "工作区 ID 不能为空");
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
throw new ZeroError("NODE_NOT_FOUND", "节点 ID 不能为空");
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* 验证并规范化项目根目录路径
|
|
48
|
+
* @param inputPath 用户输入的路径
|
|
49
|
+
* @param basePath 基准路径(默认为 cwd),用于解析相对路径
|
|
50
|
+
* @returns 规范化后的绝对路径
|
|
51
|
+
* @throws ZeroError 如果路径不安全或不存在
|
|
52
|
+
*/
|
|
53
|
+
export function validateProjectRoot(inputPath, basePath = process.cwd()) {
|
|
54
|
+
// 1. 检查输入是否为空
|
|
55
|
+
if (!inputPath || inputPath.trim().length === 0) {
|
|
56
|
+
throw new ZeroError("INVALID_PATH", "项目路径不能为空");
|
|
57
|
+
}
|
|
58
|
+
// 2. 检查是否包含危险的路径穿越模式
|
|
59
|
+
// 注意:需要在 resolve 之前检查原始输入
|
|
60
|
+
const normalizedInput = inputPath.replace(/\\/g, "/");
|
|
61
|
+
if (normalizedInput.includes("/../") ||
|
|
62
|
+
normalizedInput.startsWith("../") ||
|
|
63
|
+
normalizedInput.endsWith("/..") ||
|
|
64
|
+
normalizedInput === "..") {
|
|
65
|
+
throw new ZeroError("INVALID_PATH", "项目路径不能包含目录穿越 (..)");
|
|
66
|
+
}
|
|
67
|
+
// 3. 解析为绝对路径
|
|
68
|
+
const resolvedPath = path.resolve(basePath, inputPath);
|
|
69
|
+
// 4. 再次验证解析后的路径不会逃逸到意外位置
|
|
70
|
+
// 确保解析后的路径在用户主目录或 basePath 下
|
|
71
|
+
const homeDir = process.env.HOME || process.env.USERPROFILE || "/";
|
|
72
|
+
const isUnderHome = resolvedPath.startsWith(homeDir);
|
|
73
|
+
const isUnderBase = resolvedPath.startsWith(basePath);
|
|
74
|
+
if (!isUnderHome && !isUnderBase) {
|
|
75
|
+
throw new ZeroError("INVALID_PATH", `项目路径必须在用户主目录或当前目录下: ${resolvedPath}`);
|
|
76
|
+
}
|
|
77
|
+
// 5. 验证目录存在
|
|
78
|
+
if (!fs.existsSync(resolvedPath)) {
|
|
79
|
+
throw new ZeroError("INVALID_PATH", `项目目录不存在: ${resolvedPath}`);
|
|
80
|
+
}
|
|
81
|
+
// 6. 验证是目录而非文件
|
|
82
|
+
const stat = fs.statSync(resolvedPath);
|
|
83
|
+
if (!stat.isDirectory()) {
|
|
84
|
+
throw new ZeroError("INVALID_PATH", `路径不是目录: ${resolvedPath}`);
|
|
85
|
+
}
|
|
86
|
+
return resolvedPath;
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,389 @@
|
|
|
1
|
+
# 日志系统
|
|
2
|
+
|
|
3
|
+
> ZeroWorkspace 统一日志记录方案
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## 概述
|
|
8
|
+
|
|
9
|
+
ZeroWorkspace 日志系统提供统一的日志记录能力,支持:
|
|
10
|
+
|
|
11
|
+
- **后端系统日志**:记录 MCP 调用、系统事件等
|
|
12
|
+
- **前端错误上报**:捕获 Vue 错误、JS 异常、Promise rejection、API 错误
|
|
13
|
+
- **可配置日志级别**:支持 debug/info/warn/error 四级过滤
|
|
14
|
+
|
|
15
|
+
所有日志统一写入 `~/.zero-workspace/logs/system.log`,采用 JSON Lines 格式便于解析。
|
|
16
|
+
|
|
17
|
+
---
|
|
18
|
+
|
|
19
|
+
## 架构
|
|
20
|
+
|
|
21
|
+
```
|
|
22
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
23
|
+
│ 前端 (Vue) │
|
|
24
|
+
├─────────────────────────────────────────────────────────────────┤
|
|
25
|
+
│ Vue errorHandler │ window.onerror │ onunhandledrejection │
|
|
26
|
+
│ │ │ │
|
|
27
|
+
│ axios interceptor (API 错误) │
|
|
28
|
+
└───────────────────────────┬─────────────────────────────────────┘
|
|
29
|
+
│ POST /api/logs/client
|
|
30
|
+
▼
|
|
31
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
32
|
+
│ 后端 (Node.js) │
|
|
33
|
+
├─────────────────────────────────────────────────────────────────┤
|
|
34
|
+
│ log.ts 路由 │ sessionLogger (MCP 调用) │
|
|
35
|
+
│ │ │ │ │
|
|
36
|
+
│ └────────────────┴─────────┘ │
|
|
37
|
+
│ │ │
|
|
38
|
+
│ ▼ │
|
|
39
|
+
│ ┌─────────────────┐ │
|
|
40
|
+
│ │ Logger 单例 │ ◄── 读取 config.json logLevel │
|
|
41
|
+
│ │ (级别过滤) │ │
|
|
42
|
+
│ └────────┬────────┘ │
|
|
43
|
+
│ │ │
|
|
44
|
+
│ ▼ │
|
|
45
|
+
│ ┌─────────────────┐ │
|
|
46
|
+
│ │ 异步写入队列 │ │
|
|
47
|
+
│ └────────┬────────┘ │
|
|
48
|
+
│ │ │
|
|
49
|
+
│ ▼ │
|
|
50
|
+
│ ~/.zero-workspace/logs/system.log │
|
|
51
|
+
│ (JSON Lines, 10MB 轮转, 最多 10 个文件) │
|
|
52
|
+
└─────────────────────────────────────────────────────────────────┘
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
---
|
|
56
|
+
|
|
57
|
+
## 日志存储
|
|
58
|
+
|
|
59
|
+
### 文件位置
|
|
60
|
+
|
|
61
|
+
| 环境 | 路径 |
|
|
62
|
+
|------|------|
|
|
63
|
+
| 生产 | `~/.zero-workspace/logs/system.log` |
|
|
64
|
+
| 开发 | `~/.zero-workspace-dev/logs/system.log` |
|
|
65
|
+
|
|
66
|
+
### 日志格式 (JSON Lines)
|
|
67
|
+
|
|
68
|
+
每行是一个独立的 JSON 对象:
|
|
69
|
+
|
|
70
|
+
```json
|
|
71
|
+
{"ts":"2024-01-15T10:30:45.123Z","level":"info","source":"mcp","event":"start","tool":"node_create","sessionId":"abc123"}
|
|
72
|
+
{"ts":"2024-01-15T10:30:45.456Z","level":"error","source":"client","type":"vue","message":"Cannot read property 'x' of undefined","component":"NodeTree"}
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
### 日志字段
|
|
76
|
+
|
|
77
|
+
| 字段 | 类型 | 说明 |
|
|
78
|
+
|------|------|------|
|
|
79
|
+
| `ts` | string | ISO 8601 时间戳 |
|
|
80
|
+
| `level` | string | 日志级别:debug/info/warn/error |
|
|
81
|
+
| `source` | string | 来源标识:mcp/client/system |
|
|
82
|
+
| `...` | any | 其他动态字段,取决于日志类型 |
|
|
83
|
+
|
|
84
|
+
### 日志轮转
|
|
85
|
+
|
|
86
|
+
- **触发条件**:单个日志文件达到 10MB
|
|
87
|
+
- **保留数量**:最多 10 个文件
|
|
88
|
+
- **文件命名**:
|
|
89
|
+
- `system.log` - 当前日志
|
|
90
|
+
- `system.1.log` - 上一个
|
|
91
|
+
- `system.2.log` ~ `system.9.log` - 更早的日志
|
|
92
|
+
|
|
93
|
+
轮转时,最旧的 `system.9.log` 被删除,其余文件依次重命名。
|
|
94
|
+
|
|
95
|
+
---
|
|
96
|
+
|
|
97
|
+
## 日志级别
|
|
98
|
+
|
|
99
|
+
### 级别优先级
|
|
100
|
+
|
|
101
|
+
| 级别 | 优先级 | 说明 |
|
|
102
|
+
|------|--------|------|
|
|
103
|
+
| `debug` | 0 | 调试信息,最详细 |
|
|
104
|
+
| `info` | 1 | 常规信息(默认级别) |
|
|
105
|
+
| `warn` | 2 | 警告信息 |
|
|
106
|
+
| `error` | 3 | 错误信息 |
|
|
107
|
+
|
|
108
|
+
### 过滤规则
|
|
109
|
+
|
|
110
|
+
配置的日志级别决定最低记录级别。例如:
|
|
111
|
+
|
|
112
|
+
- 配置 `logLevel: "info"`:记录 info、warn、error,忽略 debug
|
|
113
|
+
- 配置 `logLevel: "warn"`:记录 warn、error,忽略 debug、info
|
|
114
|
+
- 配置 `logLevel: "debug"`:记录所有级别
|
|
115
|
+
|
|
116
|
+
### 配置方法
|
|
117
|
+
|
|
118
|
+
编辑 `~/.zero-workspace/config.json`:
|
|
119
|
+
|
|
120
|
+
```json
|
|
121
|
+
{
|
|
122
|
+
"version": "1.0",
|
|
123
|
+
"defaultDispatchMode": "none",
|
|
124
|
+
"logLevel": "debug"
|
|
125
|
+
}
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
或使用 MCP 工具:
|
|
129
|
+
|
|
130
|
+
```typescript
|
|
131
|
+
config_set({ logLevel: "debug" })
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
---
|
|
135
|
+
|
|
136
|
+
## 后端日志
|
|
137
|
+
|
|
138
|
+
### Logger API
|
|
139
|
+
|
|
140
|
+
```typescript
|
|
141
|
+
import { logger } from './utils/logger.js';
|
|
142
|
+
|
|
143
|
+
// 调试日志
|
|
144
|
+
logger.debug('source', { key: 'value' });
|
|
145
|
+
|
|
146
|
+
// 信息日志
|
|
147
|
+
logger.info('source', { key: 'value' });
|
|
148
|
+
|
|
149
|
+
// 警告日志
|
|
150
|
+
logger.warn('source', { key: 'value' });
|
|
151
|
+
|
|
152
|
+
// 错误日志
|
|
153
|
+
logger.error('source', { key: 'value' });
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
### MCP 调用日志
|
|
157
|
+
|
|
158
|
+
`sessionLogger` 自动记录所有 MCP 工具调用:
|
|
159
|
+
|
|
160
|
+
```typescript
|
|
161
|
+
// 调用开始
|
|
162
|
+
logMcpStart('node_create', { workspaceId: 'ws-xxx', title: '新任务' });
|
|
163
|
+
|
|
164
|
+
// 调用结束
|
|
165
|
+
logMcpEnd('node_create', true, { nodeId: 'node-xxx' }, 123);
|
|
166
|
+
|
|
167
|
+
// 调用错误
|
|
168
|
+
logMcpError('node_create', new Error('创建失败'));
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
生成的日志:
|
|
172
|
+
|
|
173
|
+
```json
|
|
174
|
+
{"ts":"...","level":"info","source":"mcp","event":"start","tool":"node_create","sessionId":"...","params":{...}}
|
|
175
|
+
{"ts":"...","level":"info","source":"mcp","event":"end","tool":"node_create","sessionId":"...","success":true,"result":"...","durationMs":123}
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
---
|
|
179
|
+
|
|
180
|
+
## 前端错误上报
|
|
181
|
+
|
|
182
|
+
### 错误类型
|
|
183
|
+
|
|
184
|
+
| 类型 | 说明 | 触发场景 |
|
|
185
|
+
|------|------|----------|
|
|
186
|
+
| `vue` | Vue 组件错误 | 组件渲染/生命周期异常 |
|
|
187
|
+
| `js` | JavaScript 错误 | 运行时异常 |
|
|
188
|
+
| `promise` | Promise rejection | 未处理的 Promise 拒绝 |
|
|
189
|
+
| `api` | API 请求错误 | HTTP 请求失败 |
|
|
190
|
+
|
|
191
|
+
### 自动捕获
|
|
192
|
+
|
|
193
|
+
前端已注册全局错误处理器,无需手动调用:
|
|
194
|
+
|
|
195
|
+
```typescript
|
|
196
|
+
// main.ts 中已配置
|
|
197
|
+
|
|
198
|
+
// 1. Vue 组件错误
|
|
199
|
+
app.config.errorHandler = (err, vm, info) => {
|
|
200
|
+
reportError({ type: 'vue', message: err.message, ... });
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
// 2. 全局 JS 错误
|
|
204
|
+
window.onerror = (message, filename, lineno, colno, error) => {
|
|
205
|
+
reportError({ type: 'js', message, ... });
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
// 3. 未处理 Promise rejection
|
|
209
|
+
window.onunhandledrejection = (event) => {
|
|
210
|
+
reportError({ type: 'promise', message: event.reason, ... });
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
// 4. API 错误(axios 拦截器)
|
|
214
|
+
// client.ts 中已配置
|
|
215
|
+
```
|
|
216
|
+
|
|
217
|
+
### 手动上报
|
|
218
|
+
|
|
219
|
+
```typescript
|
|
220
|
+
import { reportError } from '@/utils/errorReporter';
|
|
221
|
+
|
|
222
|
+
reportError({
|
|
223
|
+
type: 'js',
|
|
224
|
+
message: '自定义错误信息',
|
|
225
|
+
stack: error.stack,
|
|
226
|
+
extra: { userId: '123' }
|
|
227
|
+
});
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
### 上报数据结构
|
|
231
|
+
|
|
232
|
+
```typescript
|
|
233
|
+
interface ErrorReport {
|
|
234
|
+
type: 'vue' | 'js' | 'promise' | 'api'; // 错误类型
|
|
235
|
+
message: string; // 错误消息
|
|
236
|
+
stack?: string; // 堆栈信息
|
|
237
|
+
component?: string; // Vue 组件名(仅 vue 类型)
|
|
238
|
+
url?: string; // 页面 URL(自动填充)
|
|
239
|
+
extra?: Record<string, unknown>; // 额外信息
|
|
240
|
+
}
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
### 后端接收端点
|
|
244
|
+
|
|
245
|
+
`POST /api/logs/client`
|
|
246
|
+
|
|
247
|
+
请求体:
|
|
248
|
+
|
|
249
|
+
```json
|
|
250
|
+
{
|
|
251
|
+
"type": "vue",
|
|
252
|
+
"message": "Cannot read property 'x' of undefined",
|
|
253
|
+
"stack": "Error: ...\n at ...",
|
|
254
|
+
"component": "NodeTree",
|
|
255
|
+
"url": "http://localhost:5173/workspace/ws-xxx"
|
|
256
|
+
}
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
响应:
|
|
260
|
+
|
|
261
|
+
```json
|
|
262
|
+
{ "success": true }
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
---
|
|
266
|
+
|
|
267
|
+
## 查看日志
|
|
268
|
+
|
|
269
|
+
### 命令行查看
|
|
270
|
+
|
|
271
|
+
```bash
|
|
272
|
+
# 查看最新日志
|
|
273
|
+
tail -f ~/.zero-workspace/logs/system.log
|
|
274
|
+
|
|
275
|
+
# 格式化查看(需要 jq)
|
|
276
|
+
tail -f ~/.zero-workspace/logs/system.log | jq .
|
|
277
|
+
|
|
278
|
+
# 过滤错误日志
|
|
279
|
+
cat ~/.zero-workspace/logs/system.log | jq 'select(.level == "error")'
|
|
280
|
+
|
|
281
|
+
# 过滤前端错误
|
|
282
|
+
cat ~/.zero-workspace/logs/system.log | jq 'select(.source == "client")'
|
|
283
|
+
|
|
284
|
+
# 过滤特定 MCP 工具
|
|
285
|
+
cat ~/.zero-workspace/logs/system.log | jq 'select(.tool == "node_create")'
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
### 常用过滤
|
|
289
|
+
|
|
290
|
+
```bash
|
|
291
|
+
# 最近 10 条错误
|
|
292
|
+
cat ~/.zero-workspace/logs/system.log | jq 'select(.level == "error")' | tail -10
|
|
293
|
+
|
|
294
|
+
# 统计各级别日志数量
|
|
295
|
+
cat ~/.zero-workspace/logs/system.log | jq -r '.level' | sort | uniq -c
|
|
296
|
+
|
|
297
|
+
# 统计各来源日志数量
|
|
298
|
+
cat ~/.zero-workspace/logs/system.log | jq -r '.source' | sort | uniq -c
|
|
299
|
+
|
|
300
|
+
# 查看某时间段的日志
|
|
301
|
+
cat ~/.zero-workspace/logs/system.log | jq 'select(.ts >= "2024-01-15T10:00:00" and .ts <= "2024-01-15T11:00:00")'
|
|
302
|
+
```
|
|
303
|
+
|
|
304
|
+
---
|
|
305
|
+
|
|
306
|
+
## 故障排查
|
|
307
|
+
|
|
308
|
+
### 常见问题
|
|
309
|
+
|
|
310
|
+
**Q: 日志文件不存在?**
|
|
311
|
+
|
|
312
|
+
A: 日志目录和文件在首次写入时自动创建。检查:
|
|
313
|
+
- 是否有写入权限:`ls -la ~/.zero-workspace/`
|
|
314
|
+
- 开发环境路径不同:`~/.zero-workspace-dev/logs/`
|
|
315
|
+
|
|
316
|
+
**Q: 日志级别配置不生效?**
|
|
317
|
+
|
|
318
|
+
A:
|
|
319
|
+
1. 检查配置文件格式是否正确
|
|
320
|
+
2. 日志级别在模块加载时读取,修改后需重启服务
|
|
321
|
+
3. 无效的级别值会回退到默认值 `info`
|
|
322
|
+
|
|
323
|
+
**Q: 前端错误没有上报?**
|
|
324
|
+
|
|
325
|
+
A:
|
|
326
|
+
1. 检查网络请求是否发出(DevTools Network)
|
|
327
|
+
2. 上报失败时静默处理,不会影响用户体验
|
|
328
|
+
3. 确认后端服务正常运行
|
|
329
|
+
|
|
330
|
+
### 日志文件过大
|
|
331
|
+
|
|
332
|
+
如果磁盘空间不足,可手动清理:
|
|
333
|
+
|
|
334
|
+
```bash
|
|
335
|
+
# 删除所有轮转日志,保留当前日志
|
|
336
|
+
rm ~/.zero-workspace/logs/system.*.log
|
|
337
|
+
|
|
338
|
+
# 清空当前日志
|
|
339
|
+
> ~/.zero-workspace/logs/system.log
|
|
340
|
+
```
|
|
341
|
+
|
|
342
|
+
---
|
|
343
|
+
|
|
344
|
+
## 最佳实践
|
|
345
|
+
|
|
346
|
+
### 后端日志
|
|
347
|
+
|
|
348
|
+
1. **选择合适的来源标识**
|
|
349
|
+
- `mcp`:MCP 工具调用
|
|
350
|
+
- `system`:系统内部事件
|
|
351
|
+
- `http`:HTTP 请求/响应
|
|
352
|
+
|
|
353
|
+
2. **包含必要上下文**
|
|
354
|
+
```typescript
|
|
355
|
+
logger.info('mcp', {
|
|
356
|
+
tool: 'node_create',
|
|
357
|
+
workspaceId: 'ws-xxx',
|
|
358
|
+
params: { title: '...' }
|
|
359
|
+
});
|
|
360
|
+
```
|
|
361
|
+
|
|
362
|
+
3. **错误日志包含堆栈**
|
|
363
|
+
```typescript
|
|
364
|
+
logger.error('system', {
|
|
365
|
+
message: error.message,
|
|
366
|
+
stack: error.stack
|
|
367
|
+
});
|
|
368
|
+
```
|
|
369
|
+
|
|
370
|
+
### 前端错误
|
|
371
|
+
|
|
372
|
+
1. **使用 extra 字段补充上下文**
|
|
373
|
+
```typescript
|
|
374
|
+
reportError({
|
|
375
|
+
type: 'js',
|
|
376
|
+
message: '操作失败',
|
|
377
|
+
extra: {
|
|
378
|
+
userId: currentUser.id,
|
|
379
|
+
action: 'saveDocument'
|
|
380
|
+
}
|
|
381
|
+
});
|
|
382
|
+
```
|
|
383
|
+
|
|
384
|
+
2. **不要过度上报**
|
|
385
|
+
- 避免在循环中上报
|
|
386
|
+
- 考虑防抖/节流
|
|
387
|
+
|
|
388
|
+
3. **敏感信息脱敏**
|
|
389
|
+
- 不要上报密码、token 等敏感数据
|