@nanocollective/nanocoder 1.17.3 → 1.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +178 -13
- package/assets/nanocoder-vscode.vsix +0 -0
- package/dist/ai-sdk-client-empty-message.spec.d.ts +2 -0
- package/dist/ai-sdk-client-empty-message.spec.d.ts.map +1 -0
- package/dist/ai-sdk-client-empty-message.spec.js +124 -0
- package/dist/ai-sdk-client-empty-message.spec.js.map +1 -0
- package/dist/ai-sdk-client.d.ts +19 -3
- package/dist/ai-sdk-client.d.ts.map +1 -1
- package/dist/ai-sdk-client.js +359 -211
- package/dist/ai-sdk-client.js.map +1 -1
- package/dist/app/utils/appUtils.d.ts +1 -1
- package/dist/app/utils/appUtils.d.ts.map +1 -1
- package/dist/app/utils/appUtils.js +80 -14
- package/dist/app/utils/appUtils.js.map +1 -1
- package/dist/app.d.ts +22 -1
- package/dist/app.d.ts.map +1 -1
- package/dist/app.js +369 -53
- package/dist/app.js.map +1 -1
- package/dist/cli.js +37 -2
- package/dist/cli.js.map +1 -1
- package/dist/cli.spec.d.ts +2 -0
- package/dist/cli.spec.d.ts.map +1 -0
- package/dist/cli.spec.js +101 -0
- package/dist/cli.spec.js.map +1 -0
- package/dist/client-factory.d.ts.map +1 -1
- package/dist/client-factory.js +2 -2
- package/dist/client-factory.js.map +1 -1
- package/dist/commands/checkpoint.d.ts +6 -0
- package/dist/commands/checkpoint.d.ts.map +1 -0
- package/dist/commands/checkpoint.js +277 -0
- package/dist/commands/checkpoint.js.map +1 -0
- package/dist/commands/clear.d.ts.map +1 -1
- package/dist/commands/clear.js +1 -1
- package/dist/commands/clear.js.map +1 -1
- package/dist/commands/custom-commands.d.ts.map +1 -1
- package/dist/commands/custom-commands.js +4 -4
- package/dist/commands/custom-commands.js.map +1 -1
- package/dist/commands/exit.d.ts.map +1 -1
- package/dist/commands/exit.js.map +1 -1
- package/dist/commands/export.d.ts.map +1 -1
- package/dist/commands/export.js +2 -2
- package/dist/commands/export.js.map +1 -1
- package/dist/commands/help.d.ts.map +1 -1
- package/dist/commands/help.js +5 -5
- package/dist/commands/help.js.map +1 -1
- package/dist/commands/index.d.ts +2 -2
- package/dist/commands/index.d.ts.map +1 -1
- package/dist/commands/index.js +2 -2
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +15 -14
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/lsp.d.ts.map +1 -1
- package/dist/commands/lsp.js +6 -6
- package/dist/commands/lsp.js.map +1 -1
- package/dist/commands/mcp.d.ts +1 -1
- package/dist/commands/mcp.d.ts.map +1 -1
- package/dist/commands/mcp.js +6 -6
- package/dist/commands/mcp.js.map +1 -1
- package/dist/commands/model-database.d.ts +8 -0
- package/dist/commands/model-database.d.ts.map +1 -0
- package/dist/commands/model-database.js +193 -0
- package/dist/commands/model-database.js.map +1 -0
- package/dist/commands/model.d.ts.map +1 -1
- package/dist/commands/model.js.map +1 -1
- package/dist/commands/provider.d.ts.map +1 -1
- package/dist/commands/provider.js.map +1 -1
- package/dist/commands/setup-config.js +1 -1
- package/dist/commands/setup-config.js.map +1 -1
- package/dist/commands/status.d.ts.map +1 -1
- package/dist/commands/status.js.map +1 -1
- package/dist/commands/theme.d.ts.map +1 -1
- package/dist/commands/theme.js.map +1 -1
- package/dist/commands/update.d.ts.map +1 -1
- package/dist/commands/update.js +5 -5
- package/dist/commands/update.js.map +1 -1
- package/dist/commands/usage.d.ts.map +1 -1
- package/dist/commands/usage.js +4 -4
- package/dist/commands/usage.js.map +1 -1
- package/dist/commands.d.ts.map +1 -1
- package/dist/commands.js +1 -1
- package/dist/commands.js.map +1 -1
- package/dist/components/assistant-message.d.ts.map +1 -1
- package/dist/components/assistant-message.js +5 -4
- package/dist/components/assistant-message.js.map +1 -1
- package/dist/components/bash-execution-indicator.d.ts.map +1 -1
- package/dist/components/bash-execution-indicator.js +2 -2
- package/dist/components/bash-execution-indicator.js.map +1 -1
- package/dist/components/cancelling-indicator.js +3 -3
- package/dist/components/cancelling-indicator.js.map +1 -1
- package/dist/components/chat-queue.d.ts.map +1 -1
- package/dist/components/chat-queue.js +1 -1
- package/dist/components/chat-queue.js.map +1 -1
- package/dist/components/checkpoint-display.d.ts +8 -0
- package/dist/components/checkpoint-display.d.ts.map +1 -0
- package/dist/components/checkpoint-display.js +29 -0
- package/dist/components/checkpoint-display.js.map +1 -0
- package/dist/components/checkpoint-selector.d.ts +11 -0
- package/dist/components/checkpoint-selector.d.ts.map +1 -0
- package/dist/components/checkpoint-selector.js +55 -0
- package/dist/components/checkpoint-selector.js.map +1 -0
- package/dist/components/error-message.d.ts.map +1 -1
- package/dist/components/error-message.js +4 -4
- package/dist/components/error-message.js.map +1 -1
- package/dist/components/info-message.d.ts.map +1 -1
- package/dist/components/info-message.js +4 -4
- package/dist/components/info-message.js.map +1 -1
- package/dist/components/model-selector.d.ts.map +1 -1
- package/dist/components/model-selector.js +7 -7
- package/dist/components/model-selector.js.map +1 -1
- package/dist/components/provider-selector.d.ts.map +1 -1
- package/dist/components/provider-selector.js +6 -6
- package/dist/components/provider-selector.js.map +1 -1
- package/dist/components/security-disclaimer.d.ts.map +1 -1
- package/dist/components/security-disclaimer.js +4 -4
- package/dist/components/security-disclaimer.js.map +1 -1
- package/dist/components/status.d.ts +5 -0
- package/dist/components/status.d.ts.map +1 -1
- package/dist/components/status.js +36 -7
- package/dist/components/status.js.map +1 -1
- package/dist/components/success-message.d.ts.map +1 -1
- package/dist/components/success-message.js +4 -4
- package/dist/components/success-message.js.map +1 -1
- package/dist/components/theme-selector.d.ts.map +1 -1
- package/dist/components/theme-selector.js +8 -8
- package/dist/components/theme-selector.js.map +1 -1
- package/dist/components/tool-confirmation.d.ts.map +1 -1
- package/dist/components/tool-confirmation.js +7 -7
- package/dist/components/tool-confirmation.js.map +1 -1
- package/dist/components/tool-execution-indicator.d.ts.map +1 -1
- package/dist/components/tool-execution-indicator.js +2 -2
- package/dist/components/tool-execution-indicator.js.map +1 -1
- package/dist/components/tool-message.d.ts.map +1 -1
- package/dist/components/tool-message.js +4 -5
- package/dist/components/tool-message.js.map +1 -1
- package/dist/components/ui/titled-box.d.ts +16 -0
- package/dist/components/ui/titled-box.d.ts.map +1 -0
- package/dist/components/ui/titled-box.js +10 -0
- package/dist/components/ui/titled-box.js.map +1 -0
- package/dist/components/usage/progress-bar.d.ts.map +1 -1
- package/dist/components/usage/progress-bar.js +3 -0
- package/dist/components/usage/progress-bar.js.map +1 -1
- package/dist/components/usage/usage-display.d.ts.map +1 -1
- package/dist/components/usage/usage-display.js +7 -4
- package/dist/components/usage/usage-display.js.map +1 -1
- package/dist/components/user-input.d.ts.map +1 -1
- package/dist/components/user-input.js +9 -8
- package/dist/components/user-input.js.map +1 -1
- package/dist/components/user-message.d.ts.map +1 -1
- package/dist/components/user-message.js +1 -1
- package/dist/components/user-message.js.map +1 -1
- package/dist/components/vscode-extension-prompt.js +3 -3
- package/dist/components/vscode-extension-prompt.js.map +1 -1
- package/dist/components/warning-message.d.ts.map +1 -1
- package/dist/components/warning-message.js +4 -4
- package/dist/components/warning-message.js.map +1 -1
- package/dist/components/welcome-message.d.ts.map +1 -1
- package/dist/components/welcome-message.js +4 -4
- package/dist/components/welcome-message.js.map +1 -1
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +7 -7
- package/dist/config/index.js.map +1 -1
- package/dist/config/index.spec.js +4 -4
- package/dist/config/index.spec.js.map +1 -1
- package/dist/config/paths.spec.js +1 -1
- package/dist/config/paths.spec.js.map +1 -1
- package/dist/config/preferences.d.ts +0 -2
- package/dist/config/preferences.d.ts.map +1 -1
- package/dist/config/preferences.js +1 -11
- package/dist/config/preferences.js.map +1 -1
- package/dist/context/mode-context.d.ts +12 -0
- package/dist/context/mode-context.d.ts.map +1 -0
- package/dist/context/mode-context.js +21 -0
- package/dist/context/mode-context.js.map +1 -0
- package/dist/context/mode-context.spec.d.ts +2 -0
- package/dist/context/mode-context.spec.d.ts.map +1 -0
- package/dist/context/mode-context.spec.js +61 -0
- package/dist/context/mode-context.spec.js.map +1 -0
- package/dist/custom-commands/executor.d.ts.map +1 -1
- package/dist/custom-commands/executor.js.map +1 -1
- package/dist/custom-commands/loader.d.ts.map +1 -1
- package/dist/custom-commands/loader.js +1 -1
- package/dist/custom-commands/loader.js.map +1 -1
- package/dist/custom-commands/parser.d.ts.map +1 -1
- package/dist/custom-commands/parser.js.map +1 -1
- package/dist/hooks/useAppInitialization.d.ts +9 -5
- package/dist/hooks/useAppInitialization.d.ts.map +1 -1
- package/dist/hooks/useAppInitialization.js +119 -45
- package/dist/hooks/useAppInitialization.js.map +1 -1
- package/dist/hooks/useAppState.d.ts +28 -9
- package/dist/hooks/useAppState.d.ts.map +1 -1
- package/dist/hooks/useAppState.js +28 -8
- package/dist/hooks/useAppState.js.map +1 -1
- package/dist/hooks/useChatHandler.d.ts +5 -3
- package/dist/hooks/useChatHandler.d.ts.map +1 -1
- package/dist/hooks/useChatHandler.js +218 -118
- package/dist/hooks/useChatHandler.js.map +1 -1
- package/dist/hooks/useDirectoryTrust.js +1 -1
- package/dist/hooks/useDirectoryTrust.js.map +1 -1
- package/dist/hooks/useInputState.js +2 -2
- package/dist/hooks/useInputState.js.map +1 -1
- package/dist/hooks/useModeHandlers.d.ts +5 -5
- package/dist/hooks/useModeHandlers.d.ts.map +1 -1
- package/dist/hooks/useModeHandlers.js +12 -12
- package/dist/hooks/useModeHandlers.js.map +1 -1
- package/dist/hooks/useTerminalWidth.d.ts.map +1 -1
- package/dist/hooks/useTerminalWidth.js +3 -3
- package/dist/hooks/useTerminalWidth.js.map +1 -1
- package/dist/hooks/useTheme.d.ts.map +1 -1
- package/dist/hooks/useTheme.js +1 -1
- package/dist/hooks/useTheme.js.map +1 -1
- package/dist/hooks/useToolHandler.d.ts +1 -1
- package/dist/hooks/useToolHandler.d.ts.map +1 -1
- package/dist/hooks/useToolHandler.js +4 -4
- package/dist/hooks/useToolHandler.js.map +1 -1
- package/dist/hooks/useUIState.d.ts +1 -1
- package/dist/hooks/useUIState.d.ts.map +1 -1
- package/dist/hooks/useUIState.js.map +1 -1
- package/dist/hooks/useVSCodeServer.js +2 -2
- package/dist/hooks/useVSCodeServer.js.map +1 -1
- package/dist/init/agents-template-generator.d.ts +1 -1
- package/dist/init/agents-template-generator.d.ts.map +1 -1
- package/dist/init/agents-template-generator.js.map +1 -1
- package/dist/init/existing-rules-extractor.js +1 -1
- package/dist/init/existing-rules-extractor.js.map +1 -1
- package/dist/init/file-scanner.js +2 -2
- package/dist/init/file-scanner.js.map +1 -1
- package/dist/init/framework-detector.js +1 -1
- package/dist/init/framework-detector.js.map +1 -1
- package/dist/init/project-analyzer.d.ts +1 -1
- package/dist/init/project-analyzer.d.ts.map +1 -1
- package/dist/init/project-analyzer.js +3 -3
- package/dist/init/project-analyzer.js.map +1 -1
- package/dist/lsp/lsp-client.d.ts +1 -1
- package/dist/lsp/lsp-client.d.ts.map +1 -1
- package/dist/lsp/lsp-client.js +1 -1
- package/dist/lsp/lsp-client.js.map +1 -1
- package/dist/lsp/lsp-client.spec.js +1 -2
- package/dist/lsp/lsp-client.spec.js.map +1 -1
- package/dist/lsp/lsp-manager.d.ts +1 -1
- package/dist/lsp/lsp-manager.d.ts.map +1 -1
- package/dist/lsp/lsp-manager.js.map +1 -1
- package/dist/lsp/lsp-manager.spec.js +1 -1
- package/dist/lsp/lsp-manager.spec.js.map +1 -1
- package/dist/lsp/protocol.spec.js +1 -1
- package/dist/lsp/protocol.spec.js.map +1 -1
- package/dist/lsp/server-discovery.spec.js +1 -1
- package/dist/lsp/server-discovery.spec.js.map +1 -1
- package/dist/markdown-parser/index.spec.js.map +1 -1
- package/dist/markdown-parser/table-parser.spec.js.map +1 -1
- package/dist/mcp/mcp-client.d.ts +3 -2
- package/dist/mcp/mcp-client.d.ts.map +1 -1
- package/dist/mcp/mcp-client.js +279 -96
- package/dist/mcp/mcp-client.js.map +1 -1
- package/dist/mcp/transport-factory.d.ts +1 -1
- package/dist/mcp/transport-factory.d.ts.map +1 -1
- package/dist/mcp/transport-factory.js +16 -3
- package/dist/mcp/transport-factory.js.map +1 -1
- package/dist/mcp/transport-factory.spec.js +30 -48
- package/dist/mcp/transport-factory.spec.js.map +1 -1
- package/dist/message-handler.d.ts +1 -1
- package/dist/message-handler.d.ts.map +1 -1
- package/dist/message-handler.js +1 -1
- package/dist/message-handler.js.map +1 -1
- package/dist/model-database/database-engine.d.ts +25 -0
- package/dist/model-database/database-engine.d.ts.map +1 -0
- package/dist/model-database/database-engine.js +37 -0
- package/dist/model-database/database-engine.js.map +1 -0
- package/dist/model-database/database-engine.spec.d.ts +2 -0
- package/dist/model-database/database-engine.spec.d.ts.map +1 -0
- package/dist/model-database/database-engine.spec.js +413 -0
- package/dist/model-database/database-engine.spec.js.map +1 -0
- package/dist/model-database/model-database.d.ts +30 -0
- package/dist/model-database/model-database.d.ts.map +1 -0
- package/dist/model-database/model-database.js +82 -0
- package/dist/model-database/model-database.js.map +1 -0
- package/dist/model-database/model-database.spec.d.ts +2 -0
- package/dist/model-database/model-database.spec.d.ts.map +1 -0
- package/dist/model-database/model-database.spec.js +322 -0
- package/dist/model-database/model-database.spec.js.map +1 -0
- package/dist/model-database/model-engine.d.ts +25 -0
- package/dist/model-database/model-engine.d.ts.map +1 -0
- package/dist/model-database/model-engine.js +49 -0
- package/dist/model-database/model-engine.js.map +1 -0
- package/dist/model-database/model-engine.spec.d.ts +2 -0
- package/dist/model-database/model-engine.spec.d.ts.map +1 -0
- package/dist/model-database/model-engine.spec.js +381 -0
- package/dist/model-database/model-engine.spec.js.map +1 -0
- package/dist/model-database/model-fetcher.d.ts +14 -0
- package/dist/model-database/model-fetcher.d.ts.map +1 -0
- package/dist/model-database/model-fetcher.js +249 -0
- package/dist/model-database/model-fetcher.js.map +1 -0
- package/dist/model-database/model-fetcher.spec.d.ts +2 -0
- package/dist/model-database/model-fetcher.spec.d.ts.map +1 -0
- package/dist/model-database/model-fetcher.spec.js +498 -0
- package/dist/model-database/model-fetcher.spec.js.map +1 -0
- package/dist/models/models-cache.d.ts +1 -1
- package/dist/models/models-cache.d.ts.map +1 -1
- package/dist/models/models-cache.js +1 -1
- package/dist/models/models-cache.js.map +1 -1
- package/dist/models/models-dev-client.d.ts.map +1 -1
- package/dist/models/models-dev-client.js +23 -7
- package/dist/models/models-dev-client.js.map +1 -1
- package/dist/prompt-history.js +2 -2
- package/dist/prompt-history.js.map +1 -1
- package/dist/services/checkpoint-manager.d.ts +68 -0
- package/dist/services/checkpoint-manager.d.ts.map +1 -0
- package/dist/services/checkpoint-manager.js +345 -0
- package/dist/services/checkpoint-manager.js.map +1 -0
- package/dist/services/checkpoint-manager.spec.d.ts +2 -0
- package/dist/services/checkpoint-manager.spec.d.ts.map +1 -0
- package/dist/services/checkpoint-manager.spec.js +353 -0
- package/dist/services/checkpoint-manager.spec.js.map +1 -0
- package/dist/services/file-snapshot.d.ts +32 -0
- package/dist/services/file-snapshot.d.ts.map +1 -0
- package/dist/services/file-snapshot.js +161 -0
- package/dist/services/file-snapshot.js.map +1 -0
- package/dist/services/file-snapshot.spec.d.ts +2 -0
- package/dist/services/file-snapshot.spec.d.ts.map +1 -0
- package/dist/services/file-snapshot.spec.js +285 -0
- package/dist/services/file-snapshot.spec.js.map +1 -0
- package/dist/test-utils/render-with-theme.d.ts +7 -0
- package/dist/test-utils/render-with-theme.d.ts.map +1 -0
- package/dist/test-utils/render-with-theme.js +38 -0
- package/dist/test-utils/render-with-theme.js.map +1 -0
- package/dist/tokenization/tokenizer-factory.js +2 -2
- package/dist/tokenization/tokenizer-factory.js.map +1 -1
- package/dist/tokenization/tokenizer-factory.spec.js +2 -2
- package/dist/tokenization/tokenizer-factory.spec.js.map +1 -1
- package/dist/tokenization/tokenizers/anthropic-tokenizer.d.ts +1 -1
- package/dist/tokenization/tokenizers/anthropic-tokenizer.d.ts.map +1 -1
- package/dist/tokenization/tokenizers/anthropic-tokenizer.js.map +1 -1
- package/dist/tokenization/tokenizers/anthropic-tokenizer.spec.js.map +1 -1
- package/dist/tokenization/tokenizers/fallback-tokenizer.d.ts +1 -1
- package/dist/tokenization/tokenizers/fallback-tokenizer.d.ts.map +1 -1
- package/dist/tokenization/tokenizers/fallback-tokenizer.spec.js.map +1 -1
- package/dist/tokenization/tokenizers/llama-tokenizer.d.ts +1 -1
- package/dist/tokenization/tokenizers/llama-tokenizer.d.ts.map +1 -1
- package/dist/tokenization/tokenizers/llama-tokenizer.js.map +1 -1
- package/dist/tokenization/tokenizers/llama-tokenizer.spec.js.map +1 -1
- package/dist/tokenization/tokenizers/openai-tokenizer.d.ts +1 -1
- package/dist/tokenization/tokenizers/openai-tokenizer.d.ts.map +1 -1
- package/dist/tokenization/tokenizers/openai-tokenizer.js.map +1 -1
- package/dist/tokenization/tokenizers/openai-tokenizer.spec.js.map +1 -1
- package/dist/tool-calling/json-parser.d.ts.map +1 -1
- package/dist/tool-calling/json-parser.js +12 -14
- package/dist/tool-calling/json-parser.js.map +1 -1
- package/dist/tool-calling/json-parser.spec.js +7 -7
- package/dist/tool-calling/json-parser.spec.js.map +1 -1
- package/dist/tool-calling/tool-parser.d.ts.map +1 -1
- package/dist/tool-calling/tool-parser.js +38 -10
- package/dist/tool-calling/tool-parser.js.map +1 -1
- package/dist/tool-calling/tool-parser.spec.js +82 -4
- package/dist/tool-calling/tool-parser.spec.js.map +1 -1
- package/dist/tool-calling/xml-parser.d.ts.map +1 -1
- package/dist/tool-calling/xml-parser.js +21 -23
- package/dist/tool-calling/xml-parser.js.map +1 -1
- package/dist/tool-calling/xml-parser.spec.js +23 -3
- package/dist/tool-calling/xml-parser.spec.js.map +1 -1
- package/dist/tools/create-file.d.ts +24 -2
- package/dist/tools/create-file.d.ts.map +1 -1
- package/dist/tools/create-file.js +20 -16
- package/dist/tools/create-file.js.map +1 -1
- package/dist/tools/delete-lines.d.ts +18 -2
- package/dist/tools/delete-lines.d.ts.map +1 -1
- package/dist/tools/delete-lines.js +22 -17
- package/dist/tools/delete-lines.js.map +1 -1
- package/dist/tools/execute-bash.d.ts +2 -2
- package/dist/tools/execute-bash.d.ts.map +1 -1
- package/dist/tools/execute-bash.js +13 -12
- package/dist/tools/execute-bash.js.map +1 -1
- package/dist/tools/execute-function.spec.d.ts +2 -0
- package/dist/tools/execute-function.spec.d.ts.map +1 -0
- package/dist/tools/execute-function.spec.js +141 -0
- package/dist/tools/execute-function.spec.js.map +1 -0
- package/dist/tools/fetch-url.d.ts +16 -2
- package/dist/tools/fetch-url.d.ts.map +1 -1
- package/dist/tools/fetch-url.js +13 -13
- package/dist/tools/fetch-url.js.map +1 -1
- package/dist/tools/find-files.d.ts +18 -2
- package/dist/tools/find-files.d.ts.map +1 -1
- package/dist/tools/find-files.js +13 -11
- package/dist/tools/find-files.js.map +1 -1
- package/dist/tools/index.d.ts +2 -3
- package/dist/tools/index.d.ts.map +1 -1
- package/dist/tools/index.js +35 -25
- package/dist/tools/index.js.map +1 -1
- package/dist/tools/insert-lines.d.ts +18 -2
- package/dist/tools/insert-lines.d.ts.map +1 -1
- package/dist/tools/insert-lines.js +21 -16
- package/dist/tools/insert-lines.js.map +1 -1
- package/dist/tools/lsp-get-diagnostics.d.ts +10 -2
- package/dist/tools/lsp-get-diagnostics.d.ts.map +1 -1
- package/dist/tools/lsp-get-diagnostics.js +13 -11
- package/dist/tools/lsp-get-diagnostics.js.map +1 -1
- package/dist/tools/needs-approval.spec.d.ts +2 -0
- package/dist/tools/needs-approval.spec.d.ts.map +1 -0
- package/dist/tools/needs-approval.spec.js +308 -0
- package/dist/tools/needs-approval.spec.js.map +1 -0
- package/dist/tools/read-file.d.ts +2 -2
- package/dist/tools/read-file.d.ts.map +1 -1
- package/dist/tools/read-file.js +16 -18
- package/dist/tools/read-file.js.map +1 -1
- package/dist/tools/replace-lines.d.ts +19 -2
- package/dist/tools/replace-lines.d.ts.map +1 -1
- package/dist/tools/replace-lines.js +21 -16
- package/dist/tools/replace-lines.js.map +1 -1
- package/dist/tools/search-file-contents.d.ts +20 -2
- package/dist/tools/search-file-contents.d.ts.map +1 -1
- package/dist/tools/search-file-contents.js +17 -14
- package/dist/tools/search-file-contents.js.map +1 -1
- package/dist/tools/tool-manager.d.ts +1 -1
- package/dist/tools/tool-manager.d.ts.map +1 -1
- package/dist/tools/tool-manager.js +1 -1
- package/dist/tools/tool-manager.js.map +1 -1
- package/dist/tools/tool-registry.d.ts +1 -1
- package/dist/tools/tool-registry.d.ts.map +1 -1
- package/dist/tools/web-search.d.ts +2 -2
- package/dist/tools/web-search.d.ts.map +1 -1
- package/dist/tools/web-search.js +14 -14
- package/dist/tools/web-search.js.map +1 -1
- package/dist/types/app.d.ts +7 -4
- package/dist/types/app.d.ts.map +1 -1
- package/dist/types/checkpoint.d.ts +43 -0
- package/dist/types/checkpoint.d.ts.map +1 -0
- package/dist/types/checkpoint.js +2 -0
- package/dist/types/checkpoint.js.map +1 -0
- package/dist/types/config.d.ts +0 -1
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/core-connection-status.spec.d.ts +2 -0
- package/dist/types/core-connection-status.spec.d.ts.map +1 -0
- package/dist/types/core-connection-status.spec.js +52 -0
- package/dist/types/core-connection-status.spec.js.map +1 -0
- package/dist/types/core.d.ts +34 -29
- package/dist/types/core.d.ts.map +1 -1
- package/dist/types/core.js +1 -1
- package/dist/types/core.js.map +1 -1
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/system.d.ts +5 -30
- package/dist/types/system.d.ts.map +1 -1
- package/dist/usage/calculator.spec.js +1 -1
- package/dist/usage/calculator.spec.js.map +1 -1
- package/dist/usage/storage.d.ts +1 -1
- package/dist/usage/storage.d.ts.map +1 -1
- package/dist/usage/storage.js +9 -3
- package/dist/usage/storage.js.map +1 -1
- package/dist/usage/storage.spec.js +3 -3
- package/dist/usage/storage.spec.js.map +1 -1
- package/dist/usage/tracker.d.ts.map +1 -1
- package/dist/usage/tracker.js +1 -1
- package/dist/usage/tracker.js.map +1 -1
- package/dist/usage/tracker.spec.js +4 -4
- package/dist/usage/tracker.spec.js.map +1 -1
- package/dist/utils/atomic-deletion.spec.js +1 -1
- package/dist/utils/atomic-deletion.spec.js.map +1 -1
- package/dist/utils/checkpoint-utils.d.ts +12 -0
- package/dist/utils/checkpoint-utils.d.ts.map +1 -0
- package/dist/utils/checkpoint-utils.js +85 -0
- package/dist/utils/checkpoint-utils.js.map +1 -0
- package/dist/utils/checkpoint-utils.spec.d.ts +2 -0
- package/dist/utils/checkpoint-utils.spec.d.ts.map +1 -0
- package/dist/utils/checkpoint-utils.spec.js +182 -0
- package/dist/utils/checkpoint-utils.spec.js.map +1 -0
- package/dist/utils/error-formatter.d.ts +35 -0
- package/dist/utils/error-formatter.d.ts.map +1 -1
- package/dist/utils/error-formatter.js +123 -0
- package/dist/utils/error-formatter.js.map +1 -1
- package/dist/utils/file-autocomplete.js +2 -2
- package/dist/utils/file-autocomplete.js.map +1 -1
- package/dist/utils/file-autocomplete.spec.js +1 -1
- package/dist/utils/file-autocomplete.spec.js.map +1 -1
- package/dist/utils/file-content-loader.js +1 -1
- package/dist/utils/file-content-loader.js.map +1 -1
- package/dist/utils/file-content-loader.spec.js +4 -4
- package/dist/utils/file-content-loader.spec.js.map +1 -1
- package/dist/utils/file-mention-handler.js.map +1 -1
- package/dist/utils/file-mention-handler.spec.js +4 -4
- package/dist/utils/file-mention-handler.spec.js.map +1 -1
- package/dist/utils/file-mention-parser.spec.js +2 -2
- package/dist/utils/file-mention-parser.spec.js.map +1 -1
- package/dist/utils/installation-detector.js +2 -2
- package/dist/utils/installation-detector.js.map +1 -1
- package/dist/utils/installation-detector.spec.js +10 -17
- package/dist/utils/installation-detector.spec.js.map +1 -1
- package/dist/utils/logging/config.d.ts +41 -0
- package/dist/utils/logging/config.d.ts.map +1 -0
- package/dist/utils/logging/config.js +188 -0
- package/dist/utils/logging/config.js.map +1 -0
- package/dist/utils/logging/config.spec.d.ts +2 -0
- package/dist/utils/logging/config.spec.d.ts.map +1 -0
- package/dist/utils/logging/config.spec.js +233 -0
- package/dist/utils/logging/config.spec.js.map +1 -0
- package/dist/utils/logging/console-facade.d.ts +93 -0
- package/dist/utils/logging/console-facade.d.ts.map +1 -0
- package/dist/utils/logging/console-facade.js +295 -0
- package/dist/utils/logging/console-facade.js.map +1 -0
- package/dist/utils/logging/console-facade.spec.d.ts +2 -0
- package/dist/utils/logging/console-facade.spec.d.ts.map +1 -0
- package/dist/utils/logging/console-facade.spec.js +143 -0
- package/dist/utils/logging/console-facade.spec.js.map +1 -0
- package/dist/utils/logging/correlation.d.ts +139 -0
- package/dist/utils/logging/correlation.d.ts.map +1 -0
- package/dist/utils/logging/correlation.js +410 -0
- package/dist/utils/logging/correlation.js.map +1 -0
- package/dist/utils/logging/correlation.spec.d.ts +2 -0
- package/dist/utils/logging/correlation.spec.d.ts.map +1 -0
- package/dist/utils/logging/correlation.spec.js +449 -0
- package/dist/utils/logging/correlation.spec.js.map +1 -0
- package/dist/utils/logging/formatters.d.ts +70 -0
- package/dist/utils/logging/formatters.d.ts.map +1 -0
- package/dist/utils/logging/formatters.js +186 -0
- package/dist/utils/logging/formatters.js.map +1 -0
- package/dist/utils/logging/formatters.spec.d.ts +2 -0
- package/dist/utils/logging/formatters.spec.d.ts.map +1 -0
- package/dist/utils/logging/formatters.spec.js +356 -0
- package/dist/utils/logging/formatters.spec.js.map +1 -0
- package/dist/utils/logging/health-monitor.d.ts +216 -0
- package/dist/utils/logging/health-monitor.d.ts.map +1 -0
- package/dist/utils/logging/health-monitor.js +760 -0
- package/dist/utils/logging/health-monitor.js.map +1 -0
- package/dist/utils/logging/health-monitor.spec.d.ts +2 -0
- package/dist/utils/logging/health-monitor.spec.d.ts.map +1 -0
- package/dist/utils/logging/health-monitor.spec.js +305 -0
- package/dist/utils/logging/health-monitor.spec.js.map +1 -0
- package/dist/utils/logging/index.d.ts +100 -0
- package/dist/utils/logging/index.d.ts.map +1 -0
- package/dist/utils/logging/index.js +186 -0
- package/dist/utils/logging/index.js.map +1 -0
- package/dist/utils/logging/index.spec.d.ts +2 -0
- package/dist/utils/logging/index.spec.d.ts.map +1 -0
- package/dist/utils/logging/index.spec.js +214 -0
- package/dist/utils/logging/index.spec.js.map +1 -0
- package/dist/utils/logging/integration.spec.d.ts +2 -0
- package/dist/utils/logging/integration.spec.d.ts.map +1 -0
- package/dist/utils/logging/integration.spec.js +312 -0
- package/dist/utils/logging/integration.spec.js.map +1 -0
- package/dist/utils/logging/log-method-factory.d.ts +43 -0
- package/dist/utils/logging/log-method-factory.d.ts.map +1 -0
- package/dist/utils/logging/log-method-factory.js +176 -0
- package/dist/utils/logging/log-method-factory.js.map +1 -0
- package/dist/utils/logging/log-method-factory.spec.d.ts +2 -0
- package/dist/utils/logging/log-method-factory.spec.d.ts.map +1 -0
- package/dist/utils/logging/log-method-factory.spec.js +428 -0
- package/dist/utils/logging/log-method-factory.spec.js.map +1 -0
- package/dist/utils/logging/log-query.d.ts +275 -0
- package/dist/utils/logging/log-query.d.ts.map +1 -0
- package/dist/utils/logging/log-query.js +621 -0
- package/dist/utils/logging/log-query.js.map +1 -0
- package/dist/utils/logging/log-query.spec.d.ts +2 -0
- package/dist/utils/logging/log-query.spec.d.ts.map +1 -0
- package/dist/utils/logging/log-query.spec.js +737 -0
- package/dist/utils/logging/log-query.spec.js.map +1 -0
- package/dist/utils/logging/logger-provider.d.ts +73 -0
- package/dist/utils/logging/logger-provider.d.ts.map +1 -0
- package/dist/utils/logging/logger-provider.js +298 -0
- package/dist/utils/logging/logger-provider.js.map +1 -0
- package/dist/utils/logging/logger-provider.spec.d.ts +2 -0
- package/dist/utils/logging/logger-provider.spec.d.ts.map +1 -0
- package/dist/utils/logging/logger-provider.spec.js +204 -0
- package/dist/utils/logging/logger-provider.spec.js.map +1 -0
- package/dist/utils/logging/performance.d.ts +147 -0
- package/dist/utils/logging/performance.d.ts.map +1 -0
- package/dist/utils/logging/performance.js +520 -0
- package/dist/utils/logging/performance.js.map +1 -0
- package/dist/utils/logging/performance.spec.d.ts +2 -0
- package/dist/utils/logging/performance.spec.d.ts.map +1 -0
- package/dist/utils/logging/performance.spec.js +139 -0
- package/dist/utils/logging/performance.spec.js.map +1 -0
- package/dist/utils/logging/pino-logger.d.ts +22 -0
- package/dist/utils/logging/pino-logger.d.ts.map +1 -0
- package/dist/utils/logging/pino-logger.js +372 -0
- package/dist/utils/logging/pino-logger.js.map +1 -0
- package/dist/utils/logging/pino-logger.spec.d.ts +2 -0
- package/dist/utils/logging/pino-logger.spec.d.ts.map +1 -0
- package/dist/utils/logging/pino-logger.spec.js +294 -0
- package/dist/utils/logging/pino-logger.spec.js.map +1 -0
- package/dist/utils/logging/redaction.d.ts +38 -0
- package/dist/utils/logging/redaction.d.ts.map +1 -0
- package/dist/utils/logging/redaction.js +210 -0
- package/dist/utils/logging/redaction.js.map +1 -0
- package/dist/utils/logging/redaction.spec.d.ts +2 -0
- package/dist/utils/logging/redaction.spec.d.ts.map +1 -0
- package/dist/utils/logging/redaction.spec.js +338 -0
- package/dist/utils/logging/redaction.spec.js.map +1 -0
- package/dist/utils/logging/request-tracker.d.ts +189 -0
- package/dist/utils/logging/request-tracker.d.ts.map +1 -0
- package/dist/utils/logging/request-tracker.js +569 -0
- package/dist/utils/logging/request-tracker.js.map +1 -0
- package/dist/utils/logging/request-tracker.spec.d.ts +2 -0
- package/dist/utils/logging/request-tracker.spec.d.ts.map +1 -0
- package/dist/utils/logging/request-tracker.spec.js +868 -0
- package/dist/utils/logging/request-tracker.spec.js.map +1 -0
- package/dist/utils/logging/transports.d.ts +55 -0
- package/dist/utils/logging/transports.d.ts.map +1 -0
- package/dist/utils/logging/transports.js +252 -0
- package/dist/utils/logging/transports.js.map +1 -0
- package/dist/utils/logging/transports.spec.d.ts +2 -0
- package/dist/utils/logging/transports.spec.d.ts.map +1 -0
- package/dist/utils/logging/transports.spec.js +390 -0
- package/dist/utils/logging/transports.spec.js.map +1 -0
- package/dist/utils/logging/types.d.ts +173 -0
- package/dist/utils/logging/types.d.ts.map +1 -0
- package/dist/utils/logging/types.js +5 -0
- package/dist/utils/logging/types.js.map +1 -0
- package/dist/utils/message-queue.d.ts +64 -4
- package/dist/utils/message-queue.d.ts.map +1 -1
- package/dist/utils/message-queue.js +282 -28
- package/dist/utils/message-queue.js.map +1 -1
- package/dist/utils/paste-utils.spec.js +1 -1
- package/dist/utils/paste-utils.spec.js.map +1 -1
- package/dist/utils/prompt-processor.d.ts +2 -3
- package/dist/utils/prompt-processor.d.ts.map +1 -1
- package/dist/utils/prompt-processor.js +4 -52
- package/dist/utils/prompt-processor.js.map +1 -1
- package/dist/utils/tool-cancellation.spec.js.map +1 -1
- package/dist/utils/tool-result-display.d.ts +2 -2
- package/dist/utils/tool-result-display.d.ts.map +1 -1
- package/dist/utils/tool-result-display.js +3 -3
- package/dist/utils/tool-result-display.js.map +1 -1
- package/dist/utils/update-checker.d.ts.map +1 -1
- package/dist/utils/update-checker.js +1 -1
- package/dist/utils/update-checker.js.map +1 -1
- package/dist/utils/update-checker.spec.js +2 -2
- package/dist/utils/update-checker.spec.js.map +1 -1
- package/dist/vscode/extension-installer.js +1 -1
- package/dist/vscode/extension-installer.js.map +1 -1
- package/dist/vscode/extension-installer.spec.js +1 -1
- package/dist/vscode/extension-installer.spec.js.map +1 -1
- package/dist/vscode/protocol.spec.js +1 -1
- package/dist/vscode/protocol.spec.js.map +1 -1
- package/dist/vscode/vscode-server.d.ts.map +1 -1
- package/dist/vscode/vscode-server.js +2 -2
- package/dist/vscode/vscode-server.js.map +1 -1
- package/dist/vscode/vscode-server.spec.js.map +1 -1
- package/dist/wizard/config-wizard.d.ts.map +1 -1
- package/dist/wizard/config-wizard.js +16 -12
- package/dist/wizard/config-wizard.js.map +1 -1
- package/dist/wizard/steps/location-step.js +4 -4
- package/dist/wizard/steps/location-step.js.map +1 -1
- package/dist/wizard/steps/mcp-step.d.ts.map +1 -1
- package/dist/wizard/steps/mcp-step.js +4 -4
- package/dist/wizard/steps/mcp-step.js.map +1 -1
- package/dist/wizard/steps/provider-step.d.ts.map +1 -1
- package/dist/wizard/steps/provider-step.js +4 -4
- package/dist/wizard/steps/provider-step.js.map +1 -1
- package/dist/wizard/steps/summary-step.d.ts.map +1 -1
- package/dist/wizard/steps/summary-step.js +2 -2
- package/dist/wizard/steps/summary-step.js.map +1 -1
- package/dist/wizard/templates/provider-templates.d.ts.map +1 -1
- package/dist/wizard/templates/provider-templates.js +66 -2
- package/dist/wizard/templates/provider-templates.js.map +1 -1
- package/dist/wizard/validation-array.spec.js +1 -1
- package/dist/wizard/validation-array.spec.js.map +1 -1
- package/dist/wizard/validation.spec.js +1 -1
- package/dist/wizard/validation.spec.js.map +1 -1
- package/package.json +28 -26
- package/source/app/prompts/main-prompt.md +29 -96
- package/dist/commands/recommendations.d.ts +0 -8
- package/dist/commands/recommendations.d.ts.map +0 -1
- package/dist/commands/recommendations.js +0 -311
- package/dist/commands/recommendations.js.map +0 -1
- package/dist/commands/streaming.d.ts +0 -3
- package/dist/commands/streaming.d.ts.map +0 -1
- package/dist/commands/streaming.js +0 -23
- package/dist/commands/streaming.js.map +0 -1
- package/dist/components/thinking-indicator.d.ts +0 -3
- package/dist/components/thinking-indicator.d.ts.map +0 -1
- package/dist/components/thinking-indicator.js +0 -69
- package/dist/components/thinking-indicator.js.map +0 -1
- package/dist/recommendations/model-database.d.ts +0 -8
- package/dist/recommendations/model-database.d.ts.map +0 -1
- package/dist/recommendations/model-database.js +0 -514
- package/dist/recommendations/model-database.js.map +0 -1
- package/dist/recommendations/model-engine.d.ts +0 -16
- package/dist/recommendations/model-engine.d.ts.map +0 -1
- package/dist/recommendations/model-engine.js +0 -185
- package/dist/recommendations/model-engine.js.map +0 -1
- package/dist/recommendations/recommendation-engine.d.ts +0 -39
- package/dist/recommendations/recommendation-engine.d.ts.map +0 -1
- package/dist/recommendations/recommendation-engine.js +0 -144
- package/dist/recommendations/recommendation-engine.js.map +0 -1
- package/dist/system/detector.d.ts +0 -18
- package/dist/system/detector.d.ts.map +0 -1
- package/dist/system/detector.js +0 -140
- package/dist/system/detector.js.map +0 -1
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Main logging interface with facade pattern for backward compatibility
|
|
3
|
+
* Uses dependency injection pattern to avoid circular dependencies
|
|
4
|
+
*/
|
|
5
|
+
import { loggerProvider } from './logger-provider.js';
|
|
6
|
+
/**
|
|
7
|
+
* Initialize the logger with configuration
|
|
8
|
+
*/
|
|
9
|
+
export function initializeLogger(config) {
|
|
10
|
+
return loggerProvider.initializeLogger(config);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Get the current logger instance
|
|
14
|
+
*/
|
|
15
|
+
export function getLogger() {
|
|
16
|
+
return loggerProvider.getLogger();
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Get the current configuration
|
|
20
|
+
*/
|
|
21
|
+
export function getLoggerConfig() {
|
|
22
|
+
return loggerProvider.getLoggerConfig();
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Create a child logger with additional context
|
|
26
|
+
*/
|
|
27
|
+
// biome-ignore lint/suspicious/noExplicitAny: Dynamic bindings for logger context
|
|
28
|
+
export function createChildLogger(bindings) {
|
|
29
|
+
return loggerProvider.createChildLogger(bindings);
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Check if a log level is enabled
|
|
33
|
+
*/
|
|
34
|
+
export function isLevelEnabled(level) {
|
|
35
|
+
return loggerProvider.isLevelEnabled(level);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Convenience methods that match console.log API
|
|
39
|
+
*/
|
|
40
|
+
export const log = {
|
|
41
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
42
|
+
fatal: (msg, ...args) => getLogger().fatal(msg, ...args),
|
|
43
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
44
|
+
error: (msg, ...args) => getLogger().error(msg, ...args),
|
|
45
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
46
|
+
warn: (msg, ...args) => getLogger().warn(msg, ...args),
|
|
47
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
48
|
+
info: (msg, ...args) => getLogger().info(msg, ...args),
|
|
49
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
50
|
+
http: (msg, ...args) => getLogger().http(msg, ...args),
|
|
51
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
52
|
+
debug: (msg, ...args) => getLogger().debug(msg, ...args),
|
|
53
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for logger methods
|
|
54
|
+
trace: (msg, ...args) => getLogger().trace(msg, ...args),
|
|
55
|
+
};
|
|
56
|
+
/**
|
|
57
|
+
* Backward compatibility facade - wraps console during transition
|
|
58
|
+
* This will be gradually replaced with structured logging
|
|
59
|
+
*/
|
|
60
|
+
export const console = {
|
|
61
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for console compatibility
|
|
62
|
+
log: (...args) => {
|
|
63
|
+
// For now, use info level for console.log
|
|
64
|
+
log.info(args.join(' '));
|
|
65
|
+
// TODO: Add deprecation warning in development mode
|
|
66
|
+
if (process.env.NODE_ENV === 'development') {
|
|
67
|
+
process.stderr.write('\x1b[33m[DEPRECATED]\x1b[0m console.log() is deprecated. Use logger.info() instead.\n');
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for console compatibility
|
|
71
|
+
error: (...args) => {
|
|
72
|
+
log.error(args.join(' '));
|
|
73
|
+
},
|
|
74
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for console compatibility
|
|
75
|
+
warn: (...args) => {
|
|
76
|
+
log.warn(args.join(' '));
|
|
77
|
+
},
|
|
78
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for console compatibility
|
|
79
|
+
info: (...args) => {
|
|
80
|
+
log.info(args.join(' '));
|
|
81
|
+
},
|
|
82
|
+
// biome-ignore lint/suspicious/noExplicitAny: Variadic arguments for console compatibility
|
|
83
|
+
debug: (...args) => {
|
|
84
|
+
log.debug(args.join(' '));
|
|
85
|
+
},
|
|
86
|
+
};
|
|
87
|
+
/**
|
|
88
|
+
* Flush any pending logs
|
|
89
|
+
*/
|
|
90
|
+
export async function flush() {
|
|
91
|
+
await loggerProvider.flush();
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* End the logger and close all streams
|
|
95
|
+
*/
|
|
96
|
+
export async function end() {
|
|
97
|
+
await loggerProvider.end();
|
|
98
|
+
}
|
|
99
|
+
// Setup graceful shutdown handlers
|
|
100
|
+
process.on('SIGTERM', () => {
|
|
101
|
+
void (async () => {
|
|
102
|
+
log.info('\n[LOGGER] Received SIGTERM, flushing logs...');
|
|
103
|
+
await flush();
|
|
104
|
+
await end();
|
|
105
|
+
log.info('[LOGGER] Graceful shutdown completed');
|
|
106
|
+
})();
|
|
107
|
+
});
|
|
108
|
+
process.on('SIGINT', () => {
|
|
109
|
+
void (async () => {
|
|
110
|
+
log.info('\n[LOGGER] Received SIGINT, flushing logs...');
|
|
111
|
+
await flush();
|
|
112
|
+
await end();
|
|
113
|
+
log.info('[LOGGER] Graceful shutdown completed');
|
|
114
|
+
})();
|
|
115
|
+
});
|
|
116
|
+
// Handle uncaught exceptions and unhandled rejections
|
|
117
|
+
process.on('uncaughtException', err => {
|
|
118
|
+
void (async () => {
|
|
119
|
+
const logger = getLogger();
|
|
120
|
+
logger.fatal({ err }, 'Uncaught exception');
|
|
121
|
+
await flush();
|
|
122
|
+
process.exit(1);
|
|
123
|
+
})();
|
|
124
|
+
});
|
|
125
|
+
process.on('unhandledRejection', (reason, promise) => {
|
|
126
|
+
void (async () => {
|
|
127
|
+
const logger = getLogger();
|
|
128
|
+
logger.fatal({ reason, promise }, 'Unhandled promise rejection');
|
|
129
|
+
await flush();
|
|
130
|
+
process.exit(1);
|
|
131
|
+
})();
|
|
132
|
+
});
|
|
133
|
+
// Export for testing purposes only
|
|
134
|
+
export {
|
|
135
|
+
/** @internal */
|
|
136
|
+
createCorrelationFromHeaders,
|
|
137
|
+
/** @internal */
|
|
138
|
+
extractCorrelationId,
|
|
139
|
+
/** @internal */
|
|
140
|
+
formatCorrelationForLog,
|
|
141
|
+
/** @internal */
|
|
142
|
+
correlationMiddleware, } from './correlation.js';
|
|
143
|
+
// Export correlation utilities
|
|
144
|
+
export { generateCorrelationId, withNewCorrelationContext, getCorrelationId, } from './correlation.js';
|
|
145
|
+
// Export performance utilities
|
|
146
|
+
export { startMetrics, endMetrics, calculateMemoryDelta, formatMemoryUsage,
|
|
147
|
+
/** @internal */
|
|
148
|
+
formatBytes,
|
|
149
|
+
/** @internal */
|
|
150
|
+
globalPerformanceMonitor, } from './performance.js';
|
|
151
|
+
// Export configuration utilities
|
|
152
|
+
export {
|
|
153
|
+
/** @internal */
|
|
154
|
+
getDefaultLogDirectory,
|
|
155
|
+
/** @internal */
|
|
156
|
+
getEnvironmentConfig,
|
|
157
|
+
/** @internal */
|
|
158
|
+
validateLogLevel,
|
|
159
|
+
/** @internal */
|
|
160
|
+
normalizeLogLevel,
|
|
161
|
+
/** @internal */
|
|
162
|
+
createConfig, } from './config.js';
|
|
163
|
+
// Export transport utilities (used internally only)
|
|
164
|
+
// No exports from transports.js as they are only used internally
|
|
165
|
+
// Console facade exports (only used in tests)
|
|
166
|
+
// No exports from console-facade.js as they are only used internally and in tests
|
|
167
|
+
// Export request tracking utilities (specific instances used by other modules)
|
|
168
|
+
export { healthChecks } from './health-monitor.js';
|
|
169
|
+
// Internal exports that knip should ignore
|
|
170
|
+
/** @internal */
|
|
171
|
+
export { httpTracker } from './request-tracker.js';
|
|
172
|
+
/** @internal */
|
|
173
|
+
export { aiTracker } from './request-tracker.js';
|
|
174
|
+
/** @internal */
|
|
175
|
+
export { mcpTracker } from './request-tracker.js';
|
|
176
|
+
export { globalRequestTracker } from './request-tracker.js';
|
|
177
|
+
// Export log storage for tests
|
|
178
|
+
export { globalLogStorage } from './log-query.js';
|
|
179
|
+
// Internal exports that knip should ignore
|
|
180
|
+
/** @internal */
|
|
181
|
+
export { globalHealthMonitor } from './health-monitor.js';
|
|
182
|
+
/** @internal */
|
|
183
|
+
export { initializeHealthMonitoring } from './health-monitor.js';
|
|
184
|
+
/** @internal */
|
|
185
|
+
export { healthCheckMiddleware } from './health-monitor.js';
|
|
186
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../source/utils/logging/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.spec.d.ts","sourceRoot":"","sources":["../../../source/utils/logging/index.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, rmSync } from 'fs';
|
|
2
|
+
import { tmpdir } from 'os';
|
|
3
|
+
import { join } from 'path';
|
|
4
|
+
import test from 'ava';
|
|
5
|
+
console.log(`\nlogging/index.spec.ts`);
|
|
6
|
+
// Import the logging functions we want to test
|
|
7
|
+
import { createChildLogger, end, flush, getLogger, getLoggerConfig, initializeLogger, isLevelEnabled, log, console as structuredConsole, } from './index.js';
|
|
8
|
+
// Import logger provider for reset functionality
|
|
9
|
+
import { LoggerProvider } from './logger-provider.js';
|
|
10
|
+
// Create a temporary test directory
|
|
11
|
+
const testDir = join(tmpdir(), `nanocoder-logging-test-${Date.now()}`);
|
|
12
|
+
test.before(() => {
|
|
13
|
+
// Create test directory
|
|
14
|
+
mkdirSync(testDir, { recursive: true });
|
|
15
|
+
// Set test environment variables
|
|
16
|
+
process.env.NODE_ENV = 'test';
|
|
17
|
+
process.env.LOG_LEVEL = 'debug';
|
|
18
|
+
});
|
|
19
|
+
test.after.always(async () => {
|
|
20
|
+
// Clean up test directory
|
|
21
|
+
if (existsSync(testDir)) {
|
|
22
|
+
rmSync(testDir, { recursive: true, force: true });
|
|
23
|
+
}
|
|
24
|
+
// Reset logger state
|
|
25
|
+
await end();
|
|
26
|
+
});
|
|
27
|
+
test('initializeLogger creates a logger instance', t => {
|
|
28
|
+
const logger = initializeLogger({
|
|
29
|
+
level: 'debug',
|
|
30
|
+
pretty: true,
|
|
31
|
+
});
|
|
32
|
+
t.truthy(logger, 'Logger should be created');
|
|
33
|
+
t.is(typeof logger.info, 'function', 'Logger should have info method');
|
|
34
|
+
t.is(typeof logger.error, 'function', 'Logger should have error method');
|
|
35
|
+
t.is(typeof logger.warn, 'function', 'Logger should have warn method');
|
|
36
|
+
t.is(typeof logger.debug, 'function', 'Logger should have debug method');
|
|
37
|
+
});
|
|
38
|
+
test('getLogger returns the same logger instance', t => {
|
|
39
|
+
// Reset logger state first
|
|
40
|
+
const logger1 = initializeLogger({ level: 'info' });
|
|
41
|
+
const logger2 = getLogger();
|
|
42
|
+
const logger3 = getLogger();
|
|
43
|
+
t.is(logger1, logger2, 'Should return same instance');
|
|
44
|
+
t.is(logger2, logger3, 'Should return same instance');
|
|
45
|
+
});
|
|
46
|
+
test('getLogger auto-initializes with defaults', async (t) => {
|
|
47
|
+
// Reset logger state
|
|
48
|
+
await end();
|
|
49
|
+
const logger = getLogger();
|
|
50
|
+
t.truthy(logger, 'Should auto-initialize logger');
|
|
51
|
+
t.is(typeof logger.info, 'function', 'Should have info method');
|
|
52
|
+
});
|
|
53
|
+
test('getLoggerConfig returns current configuration', t => {
|
|
54
|
+
const config = {
|
|
55
|
+
level: 'warn',
|
|
56
|
+
pretty: false,
|
|
57
|
+
redact: ['apiKey'],
|
|
58
|
+
correlation: true,
|
|
59
|
+
serialize: true,
|
|
60
|
+
};
|
|
61
|
+
initializeLogger(config);
|
|
62
|
+
const retrievedConfig = getLoggerConfig();
|
|
63
|
+
t.truthy(retrievedConfig, 'Should return configuration');
|
|
64
|
+
// Note: The logger provider may apply default configuration overrides
|
|
65
|
+
// so we check that the level is set appropriately rather than exact match
|
|
66
|
+
t.truthy(retrievedConfig.level, 'Should have level');
|
|
67
|
+
t.is(retrievedConfig.pretty, config.pretty, 'Should match pretty setting');
|
|
68
|
+
// Check that the redaction rules include our custom rule
|
|
69
|
+
t.true(retrievedConfig.redact.includes('apiKey'), 'Should include custom redaction rule');
|
|
70
|
+
});
|
|
71
|
+
test('createChildLogger creates child with bindings', t => {
|
|
72
|
+
const parentLogger = initializeLogger({ level: 'debug' });
|
|
73
|
+
const childBindings = { module: 'test', userId: '123' };
|
|
74
|
+
const childLogger = createChildLogger(childBindings);
|
|
75
|
+
t.truthy(childLogger, 'Should create child logger');
|
|
76
|
+
t.is(typeof childLogger.info, 'function', 'Child should have info method');
|
|
77
|
+
t.not(parentLogger, childLogger, 'Should be different instance');
|
|
78
|
+
});
|
|
79
|
+
test('isLevelEnabled checks log level correctly', t => {
|
|
80
|
+
// Reset logger to ensure clean state
|
|
81
|
+
const provider = LoggerProvider.getInstance();
|
|
82
|
+
provider.reset();
|
|
83
|
+
// Initialize with debug level to ensure logging is enabled in tests
|
|
84
|
+
initializeLogger({ level: 'debug' });
|
|
85
|
+
// With debug level, these should all be enabled
|
|
86
|
+
t.true(isLevelEnabled('debug'), 'Debug should be enabled');
|
|
87
|
+
t.true(isLevelEnabled('trace'), 'Trace should be enabled');
|
|
88
|
+
t.true(isLevelEnabled('warn'), 'Warn should be enabled');
|
|
89
|
+
t.true(isLevelEnabled('error'), 'Error should be enabled');
|
|
90
|
+
t.true(isLevelEnabled('fatal'), 'Fatal should be enabled');
|
|
91
|
+
});
|
|
92
|
+
test('log convenience methods work correctly', t => {
|
|
93
|
+
const logger = initializeLogger({ level: 'debug' });
|
|
94
|
+
t.notThrows(() => {
|
|
95
|
+
log.debug('Debug message');
|
|
96
|
+
log.info('Info message');
|
|
97
|
+
log.warn('Warning message');
|
|
98
|
+
log.error('Error message');
|
|
99
|
+
log.fatal('Fatal message');
|
|
100
|
+
log.http('HTTP message');
|
|
101
|
+
log.trace('Trace message');
|
|
102
|
+
}, 'Log methods should not throw');
|
|
103
|
+
});
|
|
104
|
+
test('structured console facade provides backward compatibility', t => {
|
|
105
|
+
t.notThrows(() => {
|
|
106
|
+
structuredConsole.log('Test log message');
|
|
107
|
+
structuredConsole.info('Test info message');
|
|
108
|
+
structuredConsole.warn('Test warning message');
|
|
109
|
+
structuredConsole.error('Test error message');
|
|
110
|
+
structuredConsole.debug('Test debug message');
|
|
111
|
+
}, 'Console facade methods should not throw');
|
|
112
|
+
});
|
|
113
|
+
test('flush and end methods work correctly', async (t) => {
|
|
114
|
+
const logger = initializeLogger({ level: 'info' });
|
|
115
|
+
logger.info('Test message for flushing');
|
|
116
|
+
await t.notThrowsAsync(async () => {
|
|
117
|
+
await flush();
|
|
118
|
+
await end();
|
|
119
|
+
}, 'Flush and end should not throw');
|
|
120
|
+
});
|
|
121
|
+
test('logger handles different log levels correctly', t => {
|
|
122
|
+
const logger = initializeLogger({ level: 'warn' });
|
|
123
|
+
// These should be filtered out
|
|
124
|
+
t.notThrows(() => {
|
|
125
|
+
logger.trace('trace message');
|
|
126
|
+
logger.debug('debug message');
|
|
127
|
+
logger.info('info message');
|
|
128
|
+
logger.http('http message');
|
|
129
|
+
}, 'Filtered levels should not throw');
|
|
130
|
+
// These should be logged
|
|
131
|
+
t.notThrows(() => {
|
|
132
|
+
logger.warn('warn message');
|
|
133
|
+
logger.error('error message');
|
|
134
|
+
logger.fatal('fatal message');
|
|
135
|
+
}, 'Active levels should not throw');
|
|
136
|
+
});
|
|
137
|
+
test('logger handles structured data correctly', t => {
|
|
138
|
+
const logger = initializeLogger({ level: 'debug' });
|
|
139
|
+
const testData = {
|
|
140
|
+
userId: '123',
|
|
141
|
+
action: 'login',
|
|
142
|
+
metadata: { ip: '127.0.0.1', userAgent: 'test-agent' },
|
|
143
|
+
};
|
|
144
|
+
t.notThrows(() => {
|
|
145
|
+
logger.info('User action', testData);
|
|
146
|
+
logger.warn('Warning with data', { type: 'validation', details: testData });
|
|
147
|
+
logger.error('Error with context', {
|
|
148
|
+
error: new Error('test'),
|
|
149
|
+
context: testData,
|
|
150
|
+
});
|
|
151
|
+
}, 'Structured data should be handled correctly');
|
|
152
|
+
});
|
|
153
|
+
test('logger handles edge cases gracefully', t => {
|
|
154
|
+
const logger = initializeLogger({ level: 'debug' });
|
|
155
|
+
// Empty message
|
|
156
|
+
t.notThrows(() => {
|
|
157
|
+
logger.info('');
|
|
158
|
+
logger.info(null);
|
|
159
|
+
logger.info(undefined);
|
|
160
|
+
}, 'Edge cases should not throw');
|
|
161
|
+
// Large objects
|
|
162
|
+
const largeObject = { data: 'x'.repeat(10000) };
|
|
163
|
+
t.notThrows(() => {
|
|
164
|
+
logger.info('Large object', largeObject);
|
|
165
|
+
}, 'Large objects should be handled');
|
|
166
|
+
// Circular references
|
|
167
|
+
const circular = { a: 1 };
|
|
168
|
+
circular.self = circular;
|
|
169
|
+
t.notThrows(() => {
|
|
170
|
+
logger.info('Circular reference', circular);
|
|
171
|
+
}, 'Circular references should be handled');
|
|
172
|
+
});
|
|
173
|
+
test('logger maintains correlation context', t => {
|
|
174
|
+
const logger = initializeLogger({
|
|
175
|
+
level: 'debug',
|
|
176
|
+
correlation: true,
|
|
177
|
+
});
|
|
178
|
+
t.notThrows(() => {
|
|
179
|
+
logger.info('Message with correlation');
|
|
180
|
+
logger.child({ requestId: 'req-123' }).info('Child message');
|
|
181
|
+
}, 'Correlation context should be maintained');
|
|
182
|
+
});
|
|
183
|
+
test('logger respects redaction rules', t => {
|
|
184
|
+
const logger = initializeLogger({
|
|
185
|
+
level: 'debug',
|
|
186
|
+
redact: ['apiKey', 'token', 'password', 'secret'],
|
|
187
|
+
});
|
|
188
|
+
const sensitiveData = {
|
|
189
|
+
username: 'user123',
|
|
190
|
+
apiKey: 'sk-1234567890',
|
|
191
|
+
password: 'secret123',
|
|
192
|
+
token: 'abc123xyz',
|
|
193
|
+
safeField: 'public-data',
|
|
194
|
+
};
|
|
195
|
+
t.notThrows(() => {
|
|
196
|
+
logger.info('Login attempt', sensitiveData);
|
|
197
|
+
}, 'Redaction should not throw errors');
|
|
198
|
+
// The actual redaction would be verified by checking log output,
|
|
199
|
+
// but that requires more complex test setup with output capture
|
|
200
|
+
});
|
|
201
|
+
test('multiple logger instances do not interfere', t => {
|
|
202
|
+
const logger1 = initializeLogger({
|
|
203
|
+
level: 'debug',
|
|
204
|
+
pretty: true,
|
|
205
|
+
});
|
|
206
|
+
// This should return the existing instance
|
|
207
|
+
const logger2 = getLogger();
|
|
208
|
+
t.is(logger1, logger2, 'Should return same instance');
|
|
209
|
+
t.notThrows(() => {
|
|
210
|
+
logger1.info('Message from logger1');
|
|
211
|
+
logger2.debug('Message from logger2');
|
|
212
|
+
}, 'Multiple references should work');
|
|
213
|
+
});
|
|
214
|
+
//# sourceMappingURL=index.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.spec.js","sourceRoot":"","sources":["../../../source/utils/logging/index.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration.spec.d.ts","sourceRoot":"","sources":["../../../source/utils/logging/integration.spec.ts"],"names":[],"mappings":""}
|