snow-ai 0.4.15 → 0.4.17
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/bundle/cli.mjs +477445 -0
- package/bundle/sql-wasm.wasm +0 -0
- package/package.json +31 -26
- package/dist/agents/codebaseIndexAgent.d.ts +0 -102
- package/dist/agents/codebaseIndexAgent.js +0 -641
- package/dist/agents/codebaseReviewAgent.d.ts +0 -61
- package/dist/agents/codebaseReviewAgent.js +0 -301
- package/dist/agents/compactAgent.d.ts +0 -55
- package/dist/agents/compactAgent.js +0 -306
- package/dist/agents/promptOptimizeAgent.d.ts +0 -54
- package/dist/agents/promptOptimizeAgent.js +0 -268
- package/dist/agents/reviewAgent.d.ts +0 -50
- package/dist/agents/reviewAgent.js +0 -265
- package/dist/agents/summaryAgent.d.ts +0 -57
- package/dist/agents/summaryAgent.js +0 -260
- package/dist/api/anthropic.d.ts +0 -44
- package/dist/api/anthropic.js +0 -598
- package/dist/api/chat.d.ts +0 -73
- package/dist/api/chat.js +0 -386
- package/dist/api/embedding.d.ts +0 -34
- package/dist/api/embedding.js +0 -80
- package/dist/api/gemini.d.ts +0 -31
- package/dist/api/gemini.js +0 -445
- package/dist/api/models.d.ts +0 -15
- package/dist/api/models.js +0 -139
- package/dist/api/responses.d.ts +0 -38
- package/dist/api/responses.js +0 -515
- package/dist/api/systemPrompt.d.ts +0 -4
- package/dist/api/systemPrompt.js +0 -408
- package/dist/api/types.d.ts +0 -53
- package/dist/api/types.js +0 -4
- package/dist/app.d.ts +0 -8
- package/dist/app.js +0 -112
- package/dist/cli.d.ts +0 -2
- package/dist/cli.js +0 -199
- package/dist/hooks/useAgentPicker.d.ts +0 -14
- package/dist/hooks/useAgentPicker.js +0 -119
- package/dist/hooks/useClipboard.d.ts +0 -4
- package/dist/hooks/useClipboard.js +0 -175
- package/dist/hooks/useCommandHandler.d.ts +0 -35
- package/dist/hooks/useCommandHandler.js +0 -346
- package/dist/hooks/useCommandPanel.d.ts +0 -17
- package/dist/hooks/useCommandPanel.js +0 -114
- package/dist/hooks/useConversation.d.ts +0 -49
- package/dist/hooks/useConversation.js +0 -1052
- package/dist/hooks/useFilePicker.d.ts +0 -18
- package/dist/hooks/useFilePicker.js +0 -224
- package/dist/hooks/useGlobalExit.d.ts +0 -5
- package/dist/hooks/useGlobalExit.js +0 -34
- package/dist/hooks/useGlobalNavigation.d.ts +0 -6
- package/dist/hooks/useGlobalNavigation.js +0 -17
- package/dist/hooks/useHistoryNavigation.d.ts +0 -35
- package/dist/hooks/useHistoryNavigation.js +0 -133
- package/dist/hooks/useInputBuffer.d.ts +0 -6
- package/dist/hooks/useInputBuffer.js +0 -45
- package/dist/hooks/useKeyboardInput.d.ts +0 -80
- package/dist/hooks/useKeyboardInput.js +0 -608
- package/dist/hooks/useSessionManagement.d.ts +0 -10
- package/dist/hooks/useSessionManagement.js +0 -43
- package/dist/hooks/useSessionSave.d.ts +0 -8
- package/dist/hooks/useSessionSave.js +0 -63
- package/dist/hooks/useSnapshotState.d.ts +0 -26
- package/dist/hooks/useSnapshotState.js +0 -28
- package/dist/hooks/useStreamingState.d.ts +0 -33
- package/dist/hooks/useStreamingState.js +0 -105
- package/dist/hooks/useTerminalFocus.d.ts +0 -28
- package/dist/hooks/useTerminalFocus.js +0 -87
- package/dist/hooks/useTerminalSize.d.ts +0 -4
- package/dist/hooks/useTerminalSize.js +0 -20
- package/dist/hooks/useTodoPicker.d.ts +0 -16
- package/dist/hooks/useTodoPicker.js +0 -94
- package/dist/hooks/useToolConfirmation.d.ts +0 -19
- package/dist/hooks/useToolConfirmation.js +0 -61
- package/dist/hooks/useVSCodeState.d.ts +0 -8
- package/dist/hooks/useVSCodeState.js +0 -81
- package/dist/i18n/I18nContext.d.ts +0 -14
- package/dist/i18n/I18nContext.js +0 -24
- package/dist/i18n/index.d.ts +0 -3
- package/dist/i18n/index.js +0 -2
- package/dist/i18n/lang/en.d.ts +0 -2
- package/dist/i18n/lang/en.js +0 -502
- package/dist/i18n/lang/es.d.ts +0 -2
- package/dist/i18n/lang/es.js +0 -502
- package/dist/i18n/lang/ja.d.ts +0 -2
- package/dist/i18n/lang/ja.js +0 -502
- package/dist/i18n/lang/ko.d.ts +0 -2
- package/dist/i18n/lang/ko.js +0 -502
- package/dist/i18n/lang/zh-TW.d.ts +0 -2
- package/dist/i18n/lang/zh-TW.js +0 -502
- package/dist/i18n/lang/zh.d.ts +0 -2
- package/dist/i18n/lang/zh.js +0 -502
- package/dist/i18n/translations.d.ts +0 -2
- package/dist/i18n/translations.js +0 -14
- package/dist/i18n/types.d.ts +0 -478
- package/dist/i18n/types.js +0 -1
- package/dist/mcp/aceCodeSearch.d.ts +0 -247
- package/dist/mcp/aceCodeSearch.js +0 -1058
- package/dist/mcp/bash.d.ts +0 -50
- package/dist/mcp/bash.js +0 -153
- package/dist/mcp/codebaseSearch.d.ts +0 -44
- package/dist/mcp/codebaseSearch.js +0 -275
- package/dist/mcp/filesystem.d.ts +0 -392
- package/dist/mcp/filesystem.js +0 -1445
- package/dist/mcp/ideDiagnostics.d.ts +0 -36
- package/dist/mcp/ideDiagnostics.js +0 -90
- package/dist/mcp/notebook.d.ts +0 -10
- package/dist/mcp/notebook.js +0 -367
- package/dist/mcp/subagent.d.ts +0 -37
- package/dist/mcp/subagent.js +0 -113
- package/dist/mcp/todo.d.ts +0 -46
- package/dist/mcp/todo.js +0 -511
- package/dist/mcp/types/aceCodeSearch.types.d.ts +0 -92
- package/dist/mcp/types/aceCodeSearch.types.js +0 -4
- package/dist/mcp/types/bash.types.d.ts +0 -13
- package/dist/mcp/types/bash.types.js +0 -4
- package/dist/mcp/types/filesystem.types.d.ts +0 -210
- package/dist/mcp/types/filesystem.types.js +0 -27
- package/dist/mcp/types/todo.types.d.ts +0 -27
- package/dist/mcp/types/todo.types.js +0 -4
- package/dist/mcp/types/websearch.types.d.ts +0 -30
- package/dist/mcp/types/websearch.types.js +0 -4
- package/dist/mcp/utils/aceCodeSearch/filesystem.utils.d.ts +0 -34
- package/dist/mcp/utils/aceCodeSearch/filesystem.utils.js +0 -146
- package/dist/mcp/utils/aceCodeSearch/language.utils.d.ts +0 -14
- package/dist/mcp/utils/aceCodeSearch/language.utils.js +0 -418
- package/dist/mcp/utils/aceCodeSearch/search.utils.d.ts +0 -31
- package/dist/mcp/utils/aceCodeSearch/search.utils.js +0 -136
- package/dist/mcp/utils/aceCodeSearch/symbol.utils.d.ts +0 -20
- package/dist/mcp/utils/aceCodeSearch/symbol.utils.js +0 -141
- package/dist/mcp/utils/bash/security.utils.d.ts +0 -20
- package/dist/mcp/utils/bash/security.utils.js +0 -34
- package/dist/mcp/utils/filesystem/batch-operations.utils.d.ts +0 -39
- package/dist/mcp/utils/filesystem/batch-operations.utils.js +0 -182
- package/dist/mcp/utils/filesystem/code-analysis.utils.d.ts +0 -18
- package/dist/mcp/utils/filesystem/code-analysis.utils.js +0 -165
- package/dist/mcp/utils/filesystem/match-finder.utils.d.ts +0 -16
- package/dist/mcp/utils/filesystem/match-finder.utils.js +0 -85
- package/dist/mcp/utils/filesystem/office-parser.utils.d.ts +0 -43
- package/dist/mcp/utils/filesystem/office-parser.utils.js +0 -163
- package/dist/mcp/utils/filesystem/path-fixer.utils.d.ts +0 -7
- package/dist/mcp/utils/filesystem/path-fixer.utils.js +0 -60
- package/dist/mcp/utils/filesystem/similarity.utils.d.ts +0 -22
- package/dist/mcp/utils/filesystem/similarity.utils.js +0 -75
- package/dist/mcp/utils/todo/date.utils.d.ts +0 -9
- package/dist/mcp/utils/todo/date.utils.js +0 -14
- package/dist/mcp/utils/websearch/browser.utils.d.ts +0 -8
- package/dist/mcp/utils/websearch/browser.utils.js +0 -58
- package/dist/mcp/utils/websearch/text.utils.d.ts +0 -16
- package/dist/mcp/utils/websearch/text.utils.js +0 -39
- package/dist/mcp/websearch.d.ts +0 -88
- package/dist/mcp/websearch.js +0 -375
- package/dist/test/logger-test.d.ts +0 -1
- package/dist/test/logger-test.js +0 -7
- package/dist/types/index.d.ts +0 -15
- package/dist/types/index.js +0 -1
- package/dist/ui/components/AgentPickerPanel.d.ts +0 -10
- package/dist/ui/components/AgentPickerPanel.js +0 -74
- package/dist/ui/components/ChatInput.d.ts +0 -46
- package/dist/ui/components/ChatInput.js +0 -379
- package/dist/ui/components/CommandPanel.d.ts +0 -15
- package/dist/ui/components/CommandPanel.js +0 -80
- package/dist/ui/components/DiffViewer.d.ts +0 -11
- package/dist/ui/components/DiffViewer.js +0 -178
- package/dist/ui/components/FileList.d.ts +0 -15
- package/dist/ui/components/FileList.js +0 -360
- package/dist/ui/components/FileRollbackConfirmation.d.ts +0 -8
- package/dist/ui/components/FileRollbackConfirmation.js +0 -108
- package/dist/ui/components/HelpPanel.d.ts +0 -2
- package/dist/ui/components/HelpPanel.js +0 -67
- package/dist/ui/components/MCPInfoPanel.d.ts +0 -2
- package/dist/ui/components/MCPInfoPanel.js +0 -108
- package/dist/ui/components/MCPInfoScreen.d.ts +0 -7
- package/dist/ui/components/MCPInfoScreen.js +0 -115
- package/dist/ui/components/MarkdownRenderer.d.ts +0 -6
- package/dist/ui/components/MarkdownRenderer.js +0 -70
- package/dist/ui/components/Menu.d.ts +0 -17
- package/dist/ui/components/Menu.js +0 -88
- package/dist/ui/components/MessageList.d.ts +0 -56
- package/dist/ui/components/MessageList.js +0 -97
- package/dist/ui/components/PendingMessages.d.ts +0 -13
- package/dist/ui/components/PendingMessages.js +0 -29
- package/dist/ui/components/PendingToolCalls.d.ts +0 -11
- package/dist/ui/components/PendingToolCalls.js +0 -35
- package/dist/ui/components/ScrollableSelectInput.d.ts +0 -29
- package/dist/ui/components/ScrollableSelectInput.js +0 -157
- package/dist/ui/components/SessionListPanel.d.ts +0 -7
- package/dist/ui/components/SessionListPanel.js +0 -175
- package/dist/ui/components/SessionListScreen.d.ts +0 -7
- package/dist/ui/components/SessionListScreen.js +0 -217
- package/dist/ui/components/SessionListScreenWrapper.d.ts +0 -7
- package/dist/ui/components/SessionListScreenWrapper.js +0 -14
- package/dist/ui/components/ShimmerText.d.ts +0 -9
- package/dist/ui/components/ShimmerText.js +0 -30
- package/dist/ui/components/TodoPickerPanel.d.ts +0 -14
- package/dist/ui/components/TodoPickerPanel.js +0 -119
- package/dist/ui/components/TodoTree.d.ts +0 -15
- package/dist/ui/components/TodoTree.js +0 -60
- package/dist/ui/components/ToolConfirmation.d.ts +0 -21
- package/dist/ui/components/ToolConfirmation.js +0 -204
- package/dist/ui/components/ToolResultPreview.d.ts +0 -13
- package/dist/ui/components/ToolResultPreview.js +0 -337
- package/dist/ui/components/UsagePanel.d.ts +0 -2
- package/dist/ui/components/UsagePanel.js +0 -394
- package/dist/ui/contexts/ThemeContext.d.ts +0 -13
- package/dist/ui/contexts/ThemeContext.js +0 -28
- package/dist/ui/pages/ChatScreen.d.ts +0 -6
- package/dist/ui/pages/ChatScreen.js +0 -1495
- package/dist/ui/pages/CodeBaseConfigScreen.d.ts +0 -8
- package/dist/ui/pages/CodeBaseConfigScreen.js +0 -350
- package/dist/ui/pages/ConfigScreen.d.ts +0 -8
- package/dist/ui/pages/ConfigScreen.js +0 -1101
- package/dist/ui/pages/CustomHeadersScreen.d.ts +0 -6
- package/dist/ui/pages/CustomHeadersScreen.js +0 -502
- package/dist/ui/pages/HeadlessModeScreen.d.ts +0 -7
- package/dist/ui/pages/HeadlessModeScreen.js +0 -381
- package/dist/ui/pages/LanguageSettingsScreen.d.ts +0 -7
- package/dist/ui/pages/LanguageSettingsScreen.js +0 -91
- package/dist/ui/pages/MCPConfigScreen.d.ts +0 -6
- package/dist/ui/pages/MCPConfigScreen.js +0 -55
- package/dist/ui/pages/ProxyConfigScreen.d.ts +0 -8
- package/dist/ui/pages/ProxyConfigScreen.js +0 -149
- package/dist/ui/pages/SensitiveCommandConfigScreen.d.ts +0 -7
- package/dist/ui/pages/SensitiveCommandConfigScreen.js +0 -271
- package/dist/ui/pages/SubAgentConfigScreen.d.ts +0 -9
- package/dist/ui/pages/SubAgentConfigScreen.js +0 -435
- package/dist/ui/pages/SubAgentListScreen.d.ts +0 -9
- package/dist/ui/pages/SubAgentListScreen.js +0 -131
- package/dist/ui/pages/SystemPromptConfigScreen.d.ts +0 -6
- package/dist/ui/pages/SystemPromptConfigScreen.js +0 -326
- package/dist/ui/pages/ThemeSettingsScreen.d.ts +0 -7
- package/dist/ui/pages/ThemeSettingsScreen.js +0 -106
- package/dist/ui/pages/WelcomeScreen.d.ts +0 -7
- package/dist/ui/pages/WelcomeScreen.js +0 -217
- package/dist/ui/themes/index.d.ts +0 -23
- package/dist/ui/themes/index.js +0 -140
- package/dist/utils/apiConfig.d.ts +0 -126
- package/dist/utils/apiConfig.js +0 -423
- package/dist/utils/autoCompress.d.ts +0 -15
- package/dist/utils/autoCompress.js +0 -24
- package/dist/utils/chatExporter.d.ts +0 -9
- package/dist/utils/chatExporter.js +0 -118
- package/dist/utils/checkpointManager.d.ts +0 -74
- package/dist/utils/checkpointManager.js +0 -181
- package/dist/utils/codebaseConfig.d.ts +0 -16
- package/dist/utils/codebaseConfig.js +0 -67
- package/dist/utils/codebaseDatabase.d.ts +0 -102
- package/dist/utils/codebaseDatabase.js +0 -333
- package/dist/utils/codebaseSearchEvents.d.ts +0 -16
- package/dist/utils/codebaseSearchEvents.js +0 -13
- package/dist/utils/commandExecutor.d.ts +0 -13
- package/dist/utils/commandExecutor.js +0 -26
- package/dist/utils/commands/agent.d.ts +0 -2
- package/dist/utils/commands/agent.js +0 -12
- package/dist/utils/commands/clear.d.ts +0 -2
- package/dist/utils/commands/clear.js +0 -12
- package/dist/utils/commands/compact.d.ts +0 -2
- package/dist/utils/commands/compact.js +0 -12
- package/dist/utils/commands/export.d.ts +0 -2
- package/dist/utils/commands/export.js +0 -12
- package/dist/utils/commands/help.d.ts +0 -2
- package/dist/utils/commands/help.js +0 -11
- package/dist/utils/commands/home.d.ts +0 -2
- package/dist/utils/commands/home.js +0 -34
- package/dist/utils/commands/ide.d.ts +0 -2
- package/dist/utils/commands/ide.js +0 -32
- package/dist/utils/commands/init.d.ts +0 -2
- package/dist/utils/commands/init.js +0 -93
- package/dist/utils/commands/mcp.d.ts +0 -2
- package/dist/utils/commands/mcp.js +0 -12
- package/dist/utils/commands/resume.d.ts +0 -2
- package/dist/utils/commands/resume.js +0 -12
- package/dist/utils/commands/review.d.ts +0 -2
- package/dist/utils/commands/review.js +0 -81
- package/dist/utils/commands/role.d.ts +0 -2
- package/dist/utils/commands/role.js +0 -37
- package/dist/utils/commands/todoPicker.d.ts +0 -2
- package/dist/utils/commands/todoPicker.js +0 -12
- package/dist/utils/commands/usage.d.ts +0 -2
- package/dist/utils/commands/usage.js +0 -12
- package/dist/utils/commands/yolo.d.ts +0 -2
- package/dist/utils/commands/yolo.js +0 -12
- package/dist/utils/configManager.d.ts +0 -45
- package/dist/utils/configManager.js +0 -303
- package/dist/utils/contextCompressor.d.ts +0 -16
- package/dist/utils/contextCompressor.js +0 -334
- package/dist/utils/devMode.d.ts +0 -13
- package/dist/utils/devMode.js +0 -54
- package/dist/utils/escapeHandler.d.ts +0 -79
- package/dist/utils/escapeHandler.js +0 -153
- package/dist/utils/fileDialog.d.ts +0 -9
- package/dist/utils/fileDialog.js +0 -74
- package/dist/utils/fileUtils.d.ts +0 -40
- package/dist/utils/fileUtils.js +0 -185
- package/dist/utils/historyManager.d.ts +0 -45
- package/dist/utils/historyManager.js +0 -159
- package/dist/utils/incrementalSnapshot.d.ts +0 -109
- package/dist/utils/incrementalSnapshot.js +0 -383
- package/dist/utils/index.d.ts +0 -11
- package/dist/utils/index.js +0 -18
- package/dist/utils/languageConfig.d.ts +0 -21
- package/dist/utils/languageConfig.js +0 -61
- package/dist/utils/logger.d.ts +0 -37
- package/dist/utils/logger.js +0 -122
- package/dist/utils/mcpToolsManager.d.ts +0 -52
- package/dist/utils/mcpToolsManager.js +0 -878
- package/dist/utils/messageFormatter.d.ts +0 -12
- package/dist/utils/messageFormatter.js +0 -115
- package/dist/utils/notebookManager.d.ts +0 -59
- package/dist/utils/notebookManager.js +0 -213
- package/dist/utils/patch-highlight.d.ts +0 -5
- package/dist/utils/patch-highlight.js +0 -23
- package/dist/utils/processManager.d.ts +0 -27
- package/dist/utils/processManager.js +0 -75
- package/dist/utils/proxyUtils.d.ts +0 -15
- package/dist/utils/proxyUtils.js +0 -50
- package/dist/utils/resourceMonitor.d.ts +0 -65
- package/dist/utils/resourceMonitor.js +0 -175
- package/dist/utils/retryUtils.d.ts +0 -49
- package/dist/utils/retryUtils.js +0 -303
- package/dist/utils/sensitiveCommandManager.d.ts +0 -53
- package/dist/utils/sensitiveCommandManager.js +0 -308
- package/dist/utils/sessionConverter.d.ts +0 -7
- package/dist/utils/sessionConverter.js +0 -306
- package/dist/utils/sessionManager.d.ts +0 -53
- package/dist/utils/sessionManager.js +0 -371
- package/dist/utils/subAgentConfig.d.ts +0 -50
- package/dist/utils/subAgentConfig.js +0 -221
- package/dist/utils/subAgentExecutor.d.ts +0 -40
- package/dist/utils/subAgentExecutor.js +0 -434
- package/dist/utils/terminal.d.ts +0 -5
- package/dist/utils/terminal.js +0 -13
- package/dist/utils/textBuffer.d.ts +0 -99
- package/dist/utils/textBuffer.js +0 -547
- package/dist/utils/textUtils.d.ts +0 -37
- package/dist/utils/textUtils.js +0 -102
- package/dist/utils/themeConfig.d.ts +0 -21
- package/dist/utils/themeConfig.js +0 -61
- package/dist/utils/todoPreprocessor.d.ts +0 -5
- package/dist/utils/todoPreprocessor.js +0 -18
- package/dist/utils/todoScanner.d.ts +0 -8
- package/dist/utils/todoScanner.js +0 -148
- package/dist/utils/toolDisplayConfig.d.ts +0 -16
- package/dist/utils/toolDisplayConfig.js +0 -47
- package/dist/utils/toolExecutor.d.ts +0 -37
- package/dist/utils/toolExecutor.js +0 -224
- package/dist/utils/usageLogger.d.ts +0 -11
- package/dist/utils/usageLogger.js +0 -114
- package/dist/utils/vscodeConnection.d.ts +0 -76
- package/dist/utils/vscodeConnection.js +0 -430
- package/dist/utils/workspaceSnapshot.d.ts +0 -63
- package/dist/utils/workspaceSnapshot.js +0 -300
|
@@ -1,383 +0,0 @@
|
|
|
1
|
-
import fs from 'fs/promises';
|
|
2
|
-
import path from 'path';
|
|
3
|
-
import os from 'os';
|
|
4
|
-
import { logger } from '../utils/logger.js';
|
|
5
|
-
/**
|
|
6
|
-
* Incremental Snapshot Manager
|
|
7
|
-
* Only backs up files that are actually modified by tools
|
|
8
|
-
*/
|
|
9
|
-
class IncrementalSnapshotManager {
|
|
10
|
-
constructor() {
|
|
11
|
-
Object.defineProperty(this, "snapshotsDir", {
|
|
12
|
-
enumerable: true,
|
|
13
|
-
configurable: true,
|
|
14
|
-
writable: true,
|
|
15
|
-
value: void 0
|
|
16
|
-
});
|
|
17
|
-
Object.defineProperty(this, "activeSnapshot", {
|
|
18
|
-
enumerable: true,
|
|
19
|
-
configurable: true,
|
|
20
|
-
writable: true,
|
|
21
|
-
value: null
|
|
22
|
-
});
|
|
23
|
-
this.snapshotsDir = path.join(os.homedir(), '.snow', 'snapshots');
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Ensure snapshots directory exists
|
|
27
|
-
*/
|
|
28
|
-
async ensureSnapshotsDir() {
|
|
29
|
-
await fs.mkdir(this.snapshotsDir, { recursive: true });
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Get snapshot file path
|
|
33
|
-
*/
|
|
34
|
-
getSnapshotPath(sessionId, messageIndex) {
|
|
35
|
-
return path.join(this.snapshotsDir, `${sessionId}_${messageIndex}.json`);
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* Create a new snapshot for a message
|
|
39
|
-
*/
|
|
40
|
-
async createSnapshot(sessionId, messageIndex) {
|
|
41
|
-
this.activeSnapshot = {
|
|
42
|
-
sessionId,
|
|
43
|
-
messageIndex,
|
|
44
|
-
timestamp: Date.now(),
|
|
45
|
-
backups: []
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Backup a file before modification
|
|
50
|
-
* Call this BEFORE modifying the file
|
|
51
|
-
*/
|
|
52
|
-
async backupFile(filePath) {
|
|
53
|
-
if (!this.activeSnapshot) {
|
|
54
|
-
// No active snapshot, skip
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
// Check if already backed up
|
|
58
|
-
if (this.activeSnapshot.backups.some(b => b.path === filePath)) {
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
try {
|
|
62
|
-
// Try to read existing file
|
|
63
|
-
const content = await fs.readFile(filePath, 'utf-8');
|
|
64
|
-
this.activeSnapshot.backups.push({
|
|
65
|
-
path: filePath,
|
|
66
|
-
content,
|
|
67
|
-
existed: true
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
catch (error) {
|
|
71
|
-
// File doesn't exist, record as non-existent
|
|
72
|
-
this.activeSnapshot.backups.push({
|
|
73
|
-
path: filePath,
|
|
74
|
-
content: null,
|
|
75
|
-
existed: false
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
// Save snapshot to disk
|
|
79
|
-
await this.saveSnapshot();
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* Save current snapshot to disk
|
|
83
|
-
*/
|
|
84
|
-
async saveSnapshot() {
|
|
85
|
-
if (!this.activeSnapshot) {
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
await this.ensureSnapshotsDir();
|
|
89
|
-
const snapshotPath = this.getSnapshotPath(this.activeSnapshot.sessionId, this.activeSnapshot.messageIndex);
|
|
90
|
-
await fs.writeFile(snapshotPath, JSON.stringify(this.activeSnapshot, null, 2));
|
|
91
|
-
}
|
|
92
|
-
/**
|
|
93
|
-
* Commit snapshot (called after message completes successfully)
|
|
94
|
-
*/
|
|
95
|
-
async commitSnapshot() {
|
|
96
|
-
// Keep the snapshot for future rollback
|
|
97
|
-
this.activeSnapshot = null;
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* List all snapshots for a session
|
|
101
|
-
*/
|
|
102
|
-
async listSnapshots(sessionId) {
|
|
103
|
-
await this.ensureSnapshotsDir();
|
|
104
|
-
const snapshots = [];
|
|
105
|
-
try {
|
|
106
|
-
const files = await fs.readdir(this.snapshotsDir);
|
|
107
|
-
for (const file of files) {
|
|
108
|
-
if (file.startsWith(sessionId) && file.endsWith('.json')) {
|
|
109
|
-
const snapshotPath = path.join(this.snapshotsDir, file);
|
|
110
|
-
const content = await fs.readFile(snapshotPath, 'utf-8');
|
|
111
|
-
const metadata = JSON.parse(content);
|
|
112
|
-
snapshots.push({
|
|
113
|
-
messageIndex: metadata.messageIndex,
|
|
114
|
-
timestamp: metadata.timestamp,
|
|
115
|
-
fileCount: metadata.backups.length
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
catch (error) {
|
|
121
|
-
logger.error('Failed to list snapshots:', error);
|
|
122
|
-
}
|
|
123
|
-
return snapshots.sort((a, b) => b.messageIndex - a.messageIndex);
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* Rollback to a specific snapshot
|
|
127
|
-
*/
|
|
128
|
-
async rollbackToSnapshot(sessionId, messageIndex) {
|
|
129
|
-
const snapshotPath = this.getSnapshotPath(sessionId, messageIndex);
|
|
130
|
-
try {
|
|
131
|
-
const content = await fs.readFile(snapshotPath, 'utf-8');
|
|
132
|
-
const snapshot = JSON.parse(content);
|
|
133
|
-
// Restore all backed up files
|
|
134
|
-
for (const backup of snapshot.backups) {
|
|
135
|
-
try {
|
|
136
|
-
if (backup.existed && backup.content !== null) {
|
|
137
|
-
// Restore original file content
|
|
138
|
-
await fs.writeFile(backup.path, backup.content, 'utf-8');
|
|
139
|
-
}
|
|
140
|
-
else if (!backup.existed) {
|
|
141
|
-
// Delete file that was created
|
|
142
|
-
try {
|
|
143
|
-
await fs.unlink(backup.path);
|
|
144
|
-
}
|
|
145
|
-
catch (error) {
|
|
146
|
-
// File may not exist, ignore
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
catch (error) {
|
|
151
|
-
console.error(`Failed to restore file ${backup.path}:`, error);
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
return true;
|
|
155
|
-
}
|
|
156
|
-
catch (error) {
|
|
157
|
-
console.error('Failed to rollback snapshot:', error);
|
|
158
|
-
return false;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
/**
|
|
162
|
-
* Get list of files that will be affected by rollback to a specific message index
|
|
163
|
-
* @param sessionId Session ID
|
|
164
|
-
* @param targetMessageIndex The message index to rollback to (inclusive)
|
|
165
|
-
* @returns Array of file paths that will be rolled back
|
|
166
|
-
*/
|
|
167
|
-
async getFilesToRollback(sessionId, targetMessageIndex) {
|
|
168
|
-
await this.ensureSnapshotsDir();
|
|
169
|
-
try {
|
|
170
|
-
const files = await fs.readdir(this.snapshotsDir);
|
|
171
|
-
const filesToRollback = new Set();
|
|
172
|
-
// Load all snapshots for this session
|
|
173
|
-
for (const file of files) {
|
|
174
|
-
if (file.startsWith(sessionId) && file.endsWith('.json')) {
|
|
175
|
-
const snapshotPath = path.join(this.snapshotsDir, file);
|
|
176
|
-
const content = await fs.readFile(snapshotPath, 'utf-8');
|
|
177
|
-
const metadata = JSON.parse(content);
|
|
178
|
-
// Include files from snapshots >= targetMessageIndex
|
|
179
|
-
if (metadata.messageIndex >= targetMessageIndex) {
|
|
180
|
-
for (const backup of metadata.backups) {
|
|
181
|
-
// Convert to relative path for better display
|
|
182
|
-
const relativePath = path.relative(process.cwd(), backup.path);
|
|
183
|
-
filesToRollback.add(relativePath || backup.path);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
return Array.from(filesToRollback).sort();
|
|
189
|
-
}
|
|
190
|
-
catch (error) {
|
|
191
|
-
console.error('Failed to get files to rollback:', error);
|
|
192
|
-
return [];
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
/**
|
|
196
|
-
* Rollback all snapshots after a specific message index
|
|
197
|
-
* This is used when user selects to rollback to a specific message
|
|
198
|
-
* @param sessionId Session ID
|
|
199
|
-
* @param targetMessageIndex The message index to rollback to (inclusive)
|
|
200
|
-
* @returns Number of files rolled back
|
|
201
|
-
*/
|
|
202
|
-
async rollbackToMessageIndex(sessionId, targetMessageIndex) {
|
|
203
|
-
await this.ensureSnapshotsDir();
|
|
204
|
-
try {
|
|
205
|
-
const files = await fs.readdir(this.snapshotsDir);
|
|
206
|
-
const snapshots = [];
|
|
207
|
-
// Load all snapshots for this session
|
|
208
|
-
for (const file of files) {
|
|
209
|
-
if (file.startsWith(sessionId) && file.endsWith('.json')) {
|
|
210
|
-
const snapshotPath = path.join(this.snapshotsDir, file);
|
|
211
|
-
const content = await fs.readFile(snapshotPath, 'utf-8');
|
|
212
|
-
const metadata = JSON.parse(content);
|
|
213
|
-
snapshots.push({
|
|
214
|
-
messageIndex: metadata.messageIndex,
|
|
215
|
-
path: snapshotPath,
|
|
216
|
-
metadata
|
|
217
|
-
});
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
// Filter snapshots that are >= targetMessageIndex and sort in descending order
|
|
221
|
-
// We rollback from newest to oldest to ensure correct restoration
|
|
222
|
-
const snapshotsToRollback = snapshots
|
|
223
|
-
.filter(s => s.messageIndex >= targetMessageIndex)
|
|
224
|
-
.sort((a, b) => b.messageIndex - a.messageIndex);
|
|
225
|
-
let totalFilesRolledBack = 0;
|
|
226
|
-
// Rollback each snapshot in reverse chronological order
|
|
227
|
-
for (const snapshot of snapshotsToRollback) {
|
|
228
|
-
for (const backup of snapshot.metadata.backups) {
|
|
229
|
-
try {
|
|
230
|
-
if (backup.existed && backup.content !== null) {
|
|
231
|
-
// Restore original file content
|
|
232
|
-
await fs.writeFile(backup.path, backup.content, 'utf-8');
|
|
233
|
-
totalFilesRolledBack++;
|
|
234
|
-
}
|
|
235
|
-
else if (!backup.existed) {
|
|
236
|
-
// Delete file that was created
|
|
237
|
-
try {
|
|
238
|
-
await fs.unlink(backup.path);
|
|
239
|
-
totalFilesRolledBack++;
|
|
240
|
-
}
|
|
241
|
-
catch (error) {
|
|
242
|
-
// File may not exist, ignore
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
catch (error) {
|
|
247
|
-
console.error(`Failed to restore file ${backup.path}:`, error);
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
return totalFilesRolledBack;
|
|
252
|
-
}
|
|
253
|
-
catch (error) {
|
|
254
|
-
console.error('Failed to rollback to message index:', error);
|
|
255
|
-
return 0;
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
/**
|
|
259
|
-
* Delete all snapshots >= targetMessageIndex
|
|
260
|
-
* This is used when user rolls back conversation to clean up snapshot files
|
|
261
|
-
* @param sessionId Session ID
|
|
262
|
-
* @param targetMessageIndex The message index to delete from (inclusive)
|
|
263
|
-
*/
|
|
264
|
-
async deleteSnapshotsFromIndex(sessionId, targetMessageIndex) {
|
|
265
|
-
await this.ensureSnapshotsDir();
|
|
266
|
-
try {
|
|
267
|
-
const files = await fs.readdir(this.snapshotsDir);
|
|
268
|
-
let deletedCount = 0;
|
|
269
|
-
for (const file of files) {
|
|
270
|
-
if (file.startsWith(sessionId) && file.endsWith('.json')) {
|
|
271
|
-
const snapshotPath = path.join(this.snapshotsDir, file);
|
|
272
|
-
const content = await fs.readFile(snapshotPath, 'utf-8');
|
|
273
|
-
const metadata = JSON.parse(content);
|
|
274
|
-
// Delete snapshots with messageIndex >= targetMessageIndex
|
|
275
|
-
if (metadata.messageIndex >= targetMessageIndex) {
|
|
276
|
-
try {
|
|
277
|
-
await fs.unlink(snapshotPath);
|
|
278
|
-
deletedCount++;
|
|
279
|
-
}
|
|
280
|
-
catch (error) {
|
|
281
|
-
console.error(`Failed to delete snapshot file ${snapshotPath}:`, error);
|
|
282
|
-
}
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
return deletedCount;
|
|
287
|
-
}
|
|
288
|
-
catch (error) {
|
|
289
|
-
console.error('Failed to delete snapshots from index:', error);
|
|
290
|
-
return 0;
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
/**
|
|
294
|
-
* Clear all snapshots for a session
|
|
295
|
-
*/
|
|
296
|
-
async clearAllSnapshots(sessionId) {
|
|
297
|
-
await this.ensureSnapshotsDir();
|
|
298
|
-
try {
|
|
299
|
-
const files = await fs.readdir(this.snapshotsDir);
|
|
300
|
-
for (const file of files) {
|
|
301
|
-
if (file.startsWith(sessionId) && file.endsWith('.json')) {
|
|
302
|
-
const filePath = path.join(this.snapshotsDir, file);
|
|
303
|
-
await fs.unlink(filePath);
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
catch (error) {
|
|
308
|
-
console.error('Failed to clear snapshots:', error);
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
/**
|
|
312
|
-
* Get active snapshot
|
|
313
|
-
*/
|
|
314
|
-
getActiveSnapshot() {
|
|
315
|
-
return this.activeSnapshot;
|
|
316
|
-
}
|
|
317
|
-
/**
|
|
318
|
-
* Capture workspace state before terminal command
|
|
319
|
-
*/
|
|
320
|
-
async captureWorkspaceState(workspaceRoot = process.cwd()) {
|
|
321
|
-
const fileStates = new Map();
|
|
322
|
-
const scanDir = async (dirPath) => {
|
|
323
|
-
try {
|
|
324
|
-
const entries = await fs.readdir(dirPath, { withFileTypes: true });
|
|
325
|
-
for (const entry of entries) {
|
|
326
|
-
// Skip ignored directories
|
|
327
|
-
if (entry.isDirectory()) {
|
|
328
|
-
const dirName = entry.name;
|
|
329
|
-
if (dirName === 'node_modules' || dirName === '.git' || dirName === 'dist' ||
|
|
330
|
-
dirName === 'build' || dirName === '.snow' || dirName.startsWith('.')) {
|
|
331
|
-
continue;
|
|
332
|
-
}
|
|
333
|
-
await scanDir(path.join(dirPath, entry.name));
|
|
334
|
-
}
|
|
335
|
-
else if (entry.isFile()) {
|
|
336
|
-
const fullPath = path.join(dirPath, entry.name);
|
|
337
|
-
try {
|
|
338
|
-
const stats = await fs.stat(fullPath);
|
|
339
|
-
fileStates.set(fullPath, {
|
|
340
|
-
mtime: stats.mtimeMs,
|
|
341
|
-
size: stats.size
|
|
342
|
-
});
|
|
343
|
-
}
|
|
344
|
-
catch (error) {
|
|
345
|
-
// Skip files that can't be read
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
catch (error) {
|
|
351
|
-
// Skip directories that can't be accessed
|
|
352
|
-
}
|
|
353
|
-
};
|
|
354
|
-
await scanDir(workspaceRoot);
|
|
355
|
-
return fileStates;
|
|
356
|
-
}
|
|
357
|
-
/**
|
|
358
|
-
* Detect and backup changed files after terminal command
|
|
359
|
-
*/
|
|
360
|
-
async backupChangedFiles(beforeState, workspaceRoot = process.cwd()) {
|
|
361
|
-
const afterState = await this.captureWorkspaceState(workspaceRoot);
|
|
362
|
-
// Find modified and new files
|
|
363
|
-
for (const [filePath, afterStats] of afterState) {
|
|
364
|
-
const beforeStats = beforeState.get(filePath);
|
|
365
|
-
if (!beforeStats) {
|
|
366
|
-
// New file created - backup as non-existent
|
|
367
|
-
await this.backupFile(filePath);
|
|
368
|
-
}
|
|
369
|
-
else if (beforeStats.mtime !== afterStats.mtime || beforeStats.size !== afterStats.size) {
|
|
370
|
-
// File modified - backup original (if not already backed up)
|
|
371
|
-
await this.backupFile(filePath);
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
// Find deleted files
|
|
375
|
-
for (const [filePath] of beforeState) {
|
|
376
|
-
if (!afterState.has(filePath)) {
|
|
377
|
-
// File deleted - backup original content
|
|
378
|
-
await this.backupFile(filePath);
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
}
|
|
383
|
-
export const incrementalSnapshotManager = new IncrementalSnapshotManager();
|
package/dist/utils/index.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Command } from '../types/index.js';
|
|
2
|
-
import './commands/clear.js';
|
|
3
|
-
import './commands/resume.js';
|
|
4
|
-
export { Logger, LogLevel, logger } from './logger.js';
|
|
5
|
-
export { default as defaultLogger } from './logger.js';
|
|
6
|
-
export declare function formatCommand(command: Command): string;
|
|
7
|
-
export declare function parseInput(input: string): {
|
|
8
|
-
command: string;
|
|
9
|
-
args: string[];
|
|
10
|
-
};
|
|
11
|
-
export declare function sanitizeInput(input: string): string;
|
package/dist/utils/index.js
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// Import commands to register them
|
|
2
|
-
import './commands/clear.js';
|
|
3
|
-
import './commands/resume.js';
|
|
4
|
-
// Export logger
|
|
5
|
-
export { Logger, LogLevel, logger } from './logger.js';
|
|
6
|
-
export { default as defaultLogger } from './logger.js';
|
|
7
|
-
export function formatCommand(command) {
|
|
8
|
-
return `${command.name.padEnd(12)} ${command.description}`;
|
|
9
|
-
}
|
|
10
|
-
export function parseInput(input) {
|
|
11
|
-
const parts = input.trim().split(' ');
|
|
12
|
-
const command = parts[0] || '';
|
|
13
|
-
const args = parts.slice(1);
|
|
14
|
-
return { command, args };
|
|
15
|
-
}
|
|
16
|
-
export function sanitizeInput(input) {
|
|
17
|
-
return input.trim().replace(/[<>]/g, '');
|
|
18
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
export type Language = 'en' | 'zh' | 'zh-TW' | 'ja' | 'ko' | 'es';
|
|
2
|
-
interface LanguageConfig {
|
|
3
|
-
language: Language;
|
|
4
|
-
}
|
|
5
|
-
/**
|
|
6
|
-
* Load language configuration from file system
|
|
7
|
-
*/
|
|
8
|
-
export declare function loadLanguageConfig(): LanguageConfig;
|
|
9
|
-
/**
|
|
10
|
-
* Save language configuration to file system
|
|
11
|
-
*/
|
|
12
|
-
export declare function saveLanguageConfig(config: LanguageConfig): void;
|
|
13
|
-
/**
|
|
14
|
-
* Get current language setting
|
|
15
|
-
*/
|
|
16
|
-
export declare function getCurrentLanguage(): Language;
|
|
17
|
-
/**
|
|
18
|
-
* Set language and persist to file system
|
|
19
|
-
*/
|
|
20
|
-
export declare function setCurrentLanguage(language: Language): void;
|
|
21
|
-
export {};
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { homedir } from 'os';
|
|
2
|
-
import { join } from 'path';
|
|
3
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
|
|
4
|
-
const CONFIG_DIR = join(homedir(), '.snow');
|
|
5
|
-
const LANGUAGE_CONFIG_FILE = join(CONFIG_DIR, 'language.json');
|
|
6
|
-
const DEFAULT_CONFIG = {
|
|
7
|
-
language: 'en',
|
|
8
|
-
};
|
|
9
|
-
function ensureConfigDirectory() {
|
|
10
|
-
if (!existsSync(CONFIG_DIR)) {
|
|
11
|
-
mkdirSync(CONFIG_DIR, { recursive: true });
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Load language configuration from file system
|
|
16
|
-
*/
|
|
17
|
-
export function loadLanguageConfig() {
|
|
18
|
-
ensureConfigDirectory();
|
|
19
|
-
if (!existsSync(LANGUAGE_CONFIG_FILE)) {
|
|
20
|
-
saveLanguageConfig(DEFAULT_CONFIG);
|
|
21
|
-
return DEFAULT_CONFIG;
|
|
22
|
-
}
|
|
23
|
-
try {
|
|
24
|
-
const configData = readFileSync(LANGUAGE_CONFIG_FILE, 'utf-8');
|
|
25
|
-
const config = JSON.parse(configData);
|
|
26
|
-
return {
|
|
27
|
-
...DEFAULT_CONFIG,
|
|
28
|
-
...config,
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
catch (error) {
|
|
32
|
-
// If config file is corrupted, return default config
|
|
33
|
-
return DEFAULT_CONFIG;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Save language configuration to file system
|
|
38
|
-
*/
|
|
39
|
-
export function saveLanguageConfig(config) {
|
|
40
|
-
ensureConfigDirectory();
|
|
41
|
-
try {
|
|
42
|
-
const configData = JSON.stringify(config, null, 2);
|
|
43
|
-
writeFileSync(LANGUAGE_CONFIG_FILE, configData, 'utf-8');
|
|
44
|
-
}
|
|
45
|
-
catch (error) {
|
|
46
|
-
console.error('Failed to save language config:', error);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Get current language setting
|
|
51
|
-
*/
|
|
52
|
-
export function getCurrentLanguage() {
|
|
53
|
-
const config = loadLanguageConfig();
|
|
54
|
-
return config.language;
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Set language and persist to file system
|
|
58
|
-
*/
|
|
59
|
-
export function setCurrentLanguage(language) {
|
|
60
|
-
saveLanguageConfig({ language });
|
|
61
|
-
}
|
package/dist/utils/logger.d.ts
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
export declare enum LogLevel {
|
|
2
|
-
ERROR = 0,
|
|
3
|
-
WARN = 1,
|
|
4
|
-
INFO = 2,
|
|
5
|
-
DEBUG = 3
|
|
6
|
-
}
|
|
7
|
-
export interface LoggerConfig {
|
|
8
|
-
logDir?: string;
|
|
9
|
-
maxFileSize?: number;
|
|
10
|
-
dateFormat?: string;
|
|
11
|
-
}
|
|
12
|
-
export declare class Logger {
|
|
13
|
-
private readonly logDir;
|
|
14
|
-
private readonly maxFileSize;
|
|
15
|
-
constructor(config?: LoggerConfig);
|
|
16
|
-
private ensureLogDirectory;
|
|
17
|
-
private formatDate;
|
|
18
|
-
private formatTimestamp;
|
|
19
|
-
private getLogFilePath;
|
|
20
|
-
private shouldRotateLog;
|
|
21
|
-
private rotateLog;
|
|
22
|
-
private writeLog;
|
|
23
|
-
error(message: string, meta?: any): void;
|
|
24
|
-
warn(message: string, meta?: any): void;
|
|
25
|
-
info(message: string, meta?: any): void;
|
|
26
|
-
debug(message: string, meta?: any): void;
|
|
27
|
-
log(level: LogLevel, message: string, meta?: any): void;
|
|
28
|
-
}
|
|
29
|
-
declare const logger: {
|
|
30
|
-
error(message: string, meta?: any): void;
|
|
31
|
-
warn(message: string, meta?: any): void;
|
|
32
|
-
info(message: string, meta?: any): void;
|
|
33
|
-
debug(message: string, meta?: any): void;
|
|
34
|
-
log(level: LogLevel, message: string, meta?: any): void;
|
|
35
|
-
};
|
|
36
|
-
export default logger;
|
|
37
|
-
export { logger };
|
package/dist/utils/logger.js
DELETED
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { homedir } from 'node:os';
|
|
4
|
-
export var LogLevel;
|
|
5
|
-
(function (LogLevel) {
|
|
6
|
-
LogLevel[LogLevel["ERROR"] = 0] = "ERROR";
|
|
7
|
-
LogLevel[LogLevel["WARN"] = 1] = "WARN";
|
|
8
|
-
LogLevel[LogLevel["INFO"] = 2] = "INFO";
|
|
9
|
-
LogLevel[LogLevel["DEBUG"] = 3] = "DEBUG";
|
|
10
|
-
})(LogLevel || (LogLevel = {}));
|
|
11
|
-
export class Logger {
|
|
12
|
-
constructor(config = {}) {
|
|
13
|
-
Object.defineProperty(this, "logDir", {
|
|
14
|
-
enumerable: true,
|
|
15
|
-
configurable: true,
|
|
16
|
-
writable: true,
|
|
17
|
-
value: void 0
|
|
18
|
-
});
|
|
19
|
-
Object.defineProperty(this, "maxFileSize", {
|
|
20
|
-
enumerable: true,
|
|
21
|
-
configurable: true,
|
|
22
|
-
writable: true,
|
|
23
|
-
value: void 0
|
|
24
|
-
});
|
|
25
|
-
this.logDir = config.logDir || path.join(homedir(), '.snow', 'log');
|
|
26
|
-
this.maxFileSize = config.maxFileSize || 10 * 1024 * 1024; // 10MB
|
|
27
|
-
this.ensureLogDirectory();
|
|
28
|
-
}
|
|
29
|
-
ensureLogDirectory() {
|
|
30
|
-
if (!fs.existsSync(this.logDir)) {
|
|
31
|
-
fs.mkdirSync(this.logDir, { recursive: true });
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
formatDate(date) {
|
|
35
|
-
const year = date.getFullYear();
|
|
36
|
-
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
37
|
-
const day = String(date.getDate()).padStart(2, '0');
|
|
38
|
-
return `${year}-${month}-${day}`;
|
|
39
|
-
}
|
|
40
|
-
formatTimestamp(date) {
|
|
41
|
-
return date.toISOString();
|
|
42
|
-
}
|
|
43
|
-
getLogFilePath(level) {
|
|
44
|
-
const dateString = this.formatDate(new Date());
|
|
45
|
-
const levelName = LogLevel[level].toLowerCase();
|
|
46
|
-
return path.join(this.logDir, `${dateString}-${levelName}.log`);
|
|
47
|
-
}
|
|
48
|
-
shouldRotateLog(filePath) {
|
|
49
|
-
if (!fs.existsSync(filePath)) {
|
|
50
|
-
return false;
|
|
51
|
-
}
|
|
52
|
-
const stats = fs.statSync(filePath);
|
|
53
|
-
return stats.size >= this.maxFileSize;
|
|
54
|
-
}
|
|
55
|
-
rotateLog(filePath) {
|
|
56
|
-
const timestamp = Date.now();
|
|
57
|
-
const ext = path.extname(filePath);
|
|
58
|
-
const basename = path.basename(filePath, ext);
|
|
59
|
-
const dirname = path.dirname(filePath);
|
|
60
|
-
const rotatedPath = path.join(dirname, `${basename}-${timestamp}${ext}`);
|
|
61
|
-
fs.renameSync(filePath, rotatedPath);
|
|
62
|
-
}
|
|
63
|
-
writeLog(level, message, meta) {
|
|
64
|
-
const timestamp = this.formatTimestamp(new Date());
|
|
65
|
-
const levelName = LogLevel[level].toUpperCase().padEnd(5);
|
|
66
|
-
const logEntry = {
|
|
67
|
-
timestamp,
|
|
68
|
-
level: levelName.trim(),
|
|
69
|
-
message,
|
|
70
|
-
...(meta && { meta }),
|
|
71
|
-
};
|
|
72
|
-
const logLine = JSON.stringify(logEntry) + '\n';
|
|
73
|
-
const filePath = this.getLogFilePath(level);
|
|
74
|
-
if (this.shouldRotateLog(filePath)) {
|
|
75
|
-
this.rotateLog(filePath);
|
|
76
|
-
}
|
|
77
|
-
fs.appendFileSync(filePath, logLine, 'utf8');
|
|
78
|
-
}
|
|
79
|
-
error(message, meta) {
|
|
80
|
-
this.writeLog(LogLevel.ERROR, message, meta);
|
|
81
|
-
}
|
|
82
|
-
warn(message, meta) {
|
|
83
|
-
this.writeLog(LogLevel.WARN, message, meta);
|
|
84
|
-
}
|
|
85
|
-
info(message, meta) {
|
|
86
|
-
this.writeLog(LogLevel.INFO, message, meta);
|
|
87
|
-
}
|
|
88
|
-
debug(message, meta) {
|
|
89
|
-
this.writeLog(LogLevel.DEBUG, message, meta);
|
|
90
|
-
}
|
|
91
|
-
log(level, message, meta) {
|
|
92
|
-
this.writeLog(level, message, meta);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
// Lazy initialization to avoid blocking startup
|
|
96
|
-
let _defaultLogger = null;
|
|
97
|
-
function getDefaultLogger() {
|
|
98
|
-
if (!_defaultLogger) {
|
|
99
|
-
_defaultLogger = new Logger();
|
|
100
|
-
}
|
|
101
|
-
return _defaultLogger;
|
|
102
|
-
}
|
|
103
|
-
// Create a proxy object that lazily initializes the logger
|
|
104
|
-
const logger = {
|
|
105
|
-
error(message, meta) {
|
|
106
|
-
getDefaultLogger().error(message, meta);
|
|
107
|
-
},
|
|
108
|
-
warn(message, meta) {
|
|
109
|
-
getDefaultLogger().warn(message, meta);
|
|
110
|
-
},
|
|
111
|
-
info(message, meta) {
|
|
112
|
-
getDefaultLogger().info(message, meta);
|
|
113
|
-
},
|
|
114
|
-
debug(message, meta) {
|
|
115
|
-
getDefaultLogger().debug(message, meta);
|
|
116
|
-
},
|
|
117
|
-
log(level, message, meta) {
|
|
118
|
-
getDefaultLogger().log(level, message, meta);
|
|
119
|
-
},
|
|
120
|
-
};
|
|
121
|
-
export default logger;
|
|
122
|
-
export { logger };
|