@gguf/coder 0.3.1 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +2 -2
- package/pnpm-workspace.yaml +15 -0
- package/color_picker.html +0 -36
- package/scripts/extract-changelog.js +0 -73
- package/scripts/fetch-models.js +0 -143
- package/scripts/test.sh +0 -40
- package/scripts/update-homebrew-formula.sh +0 -125
- package/scripts/update-nix-version.sh +0 -157
- package/source/ai-sdk-client/AISDKClient.spec.ts +0 -117
- package/source/ai-sdk-client/AISDKClient.ts +0 -155
- package/source/ai-sdk-client/chat/chat-handler.spec.ts +0 -121
- package/source/ai-sdk-client/chat/chat-handler.ts +0 -276
- package/source/ai-sdk-client/chat/streaming-handler.spec.ts +0 -173
- package/source/ai-sdk-client/chat/streaming-handler.ts +0 -110
- package/source/ai-sdk-client/chat/tool-processor.spec.ts +0 -92
- package/source/ai-sdk-client/chat/tool-processor.ts +0 -70
- package/source/ai-sdk-client/converters/message-converter.spec.ts +0 -220
- package/source/ai-sdk-client/converters/message-converter.ts +0 -113
- package/source/ai-sdk-client/converters/tool-converter.spec.ts +0 -90
- package/source/ai-sdk-client/converters/tool-converter.ts +0 -46
- package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +0 -55
- package/source/ai-sdk-client/error-handling/error-extractor.ts +0 -15
- package/source/ai-sdk-client/error-handling/error-parser.spec.ts +0 -169
- package/source/ai-sdk-client/error-handling/error-parser.ts +0 -161
- package/source/ai-sdk-client/index.ts +0 -7
- package/source/ai-sdk-client/providers/provider-factory.spec.ts +0 -71
- package/source/ai-sdk-client/providers/provider-factory.ts +0 -41
- package/source/ai-sdk-client/types.ts +0 -9
- package/source/ai-sdk-client-empty-message.spec.ts +0 -141
- package/source/ai-sdk-client-error-handling.spec.ts +0 -186
- package/source/ai-sdk-client-maxretries.spec.ts +0 -114
- package/source/ai-sdk-client-preparestep.spec.ts +0 -279
- package/source/app/App.spec.tsx +0 -32
- package/source/app/App.tsx +0 -480
- package/source/app/components/AppContainer.spec.tsx +0 -96
- package/source/app/components/AppContainer.tsx +0 -56
- package/source/app/components/ChatInterface.spec.tsx +0 -163
- package/source/app/components/ChatInterface.tsx +0 -144
- package/source/app/components/ModalSelectors.spec.tsx +0 -141
- package/source/app/components/ModalSelectors.tsx +0 -135
- package/source/app/helpers.spec.ts +0 -97
- package/source/app/helpers.ts +0 -63
- package/source/app/index.ts +0 -4
- package/source/app/types.ts +0 -39
- package/source/app/utils/appUtils.ts +0 -294
- package/source/app/utils/conversationState.ts +0 -310
- package/source/app.spec.tsx +0 -244
- package/source/cli.spec.ts +0 -73
- package/source/cli.tsx +0 -51
- package/source/client-factory.spec.ts +0 -48
- package/source/client-factory.ts +0 -178
- package/source/command-parser.spec.ts +0 -127
- package/source/command-parser.ts +0 -36
- package/source/commands/checkpoint.spec.tsx +0 -277
- package/source/commands/checkpoint.tsx +0 -366
- package/source/commands/clear.tsx +0 -22
- package/source/commands/custom-commands.tsx +0 -121
- package/source/commands/exit.ts +0 -21
- package/source/commands/export.spec.tsx +0 -131
- package/source/commands/export.tsx +0 -79
- package/source/commands/help.tsx +0 -120
- package/source/commands/index.ts +0 -17
- package/source/commands/init.tsx +0 -339
- package/source/commands/lsp-command.spec.tsx +0 -281
- package/source/commands/lsp.tsx +0 -120
- package/source/commands/mcp-command.spec.tsx +0 -313
- package/source/commands/mcp.tsx +0 -162
- package/source/commands/model-database.spec.tsx +0 -758
- package/source/commands/model-database.tsx +0 -418
- package/source/commands/model.ts +0 -12
- package/source/commands/provider.ts +0 -12
- package/source/commands/setup-config.tsx +0 -16
- package/source/commands/simple-commands.spec.tsx +0 -175
- package/source/commands/status.ts +0 -12
- package/source/commands/theme.ts +0 -12
- package/source/commands/update.spec.tsx +0 -261
- package/source/commands/update.tsx +0 -201
- package/source/commands/usage.spec.tsx +0 -495
- package/source/commands/usage.tsx +0 -100
- package/source/commands.spec.ts +0 -436
- package/source/commands.ts +0 -83
- package/source/components/assistant-message.spec.tsx +0 -796
- package/source/components/assistant-message.tsx +0 -34
- package/source/components/bash-execution-indicator.tsx +0 -21
- package/source/components/cancelling-indicator.tsx +0 -16
- package/source/components/chat-queue.spec.tsx +0 -83
- package/source/components/chat-queue.tsx +0 -36
- package/source/components/checkpoint-display.spec.tsx +0 -219
- package/source/components/checkpoint-display.tsx +0 -126
- package/source/components/checkpoint-selector.spec.tsx +0 -173
- package/source/components/checkpoint-selector.tsx +0 -173
- package/source/components/development-mode-indicator.spec.tsx +0 -268
- package/source/components/development-mode-indicator.tsx +0 -38
- package/source/components/message-box.spec.tsx +0 -427
- package/source/components/message-box.tsx +0 -87
- package/source/components/model-selector.tsx +0 -132
- package/source/components/provider-selector.tsx +0 -75
- package/source/components/random-spinner.tsx +0 -19
- package/source/components/security-disclaimer.tsx +0 -73
- package/source/components/status-connection-display.spec.tsx +0 -133
- package/source/components/status.tsx +0 -267
- package/source/components/theme-selector.tsx +0 -126
- package/source/components/tool-confirmation.tsx +0 -190
- package/source/components/tool-execution-indicator.tsx +0 -33
- package/source/components/tool-message.tsx +0 -85
- package/source/components/ui/titled-box.spec.tsx +0 -207
- package/source/components/ui/titled-box.tsx +0 -57
- package/source/components/usage/progress-bar.spec.tsx +0 -398
- package/source/components/usage/progress-bar.tsx +0 -30
- package/source/components/usage/usage-display.spec.tsx +0 -780
- package/source/components/usage/usage-display.tsx +0 -291
- package/source/components/user-input.spec.tsx +0 -327
- package/source/components/user-input.tsx +0 -533
- package/source/components/user-message.spec.tsx +0 -230
- package/source/components/user-message.tsx +0 -84
- package/source/components/welcome-message.tsx +0 -76
- package/source/config/env-substitution.ts +0 -65
- package/source/config/index.spec.ts +0 -171
- package/source/config/index.ts +0 -154
- package/source/config/paths.spec.ts +0 -241
- package/source/config/paths.ts +0 -55
- package/source/config/preferences.ts +0 -51
- package/source/config/themes.ts +0 -315
- package/source/constants.ts +0 -130
- package/source/context/mode-context.spec.ts +0 -79
- package/source/context/mode-context.ts +0 -24
- package/source/custom-commands/executor.spec.ts +0 -142
- package/source/custom-commands/executor.ts +0 -64
- package/source/custom-commands/loader.spec.ts +0 -314
- package/source/custom-commands/loader.ts +0 -153
- package/source/custom-commands/parser.ts +0 -196
- package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +0 -39
- package/source/hooks/chat-handler/conversation/conversation-loop.tsx +0 -511
- package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +0 -50
- package/source/hooks/chat-handler/conversation/tool-executor.tsx +0 -109
- package/source/hooks/chat-handler/index.ts +0 -12
- package/source/hooks/chat-handler/state/streaming-state.spec.ts +0 -26
- package/source/hooks/chat-handler/state/streaming-state.ts +0 -19
- package/source/hooks/chat-handler/types.ts +0 -38
- package/source/hooks/chat-handler/useChatHandler.spec.tsx +0 -321
- package/source/hooks/chat-handler/useChatHandler.tsx +0 -194
- package/source/hooks/chat-handler/utils/context-checker.spec.ts +0 -60
- package/source/hooks/chat-handler/utils/context-checker.tsx +0 -73
- package/source/hooks/chat-handler/utils/message-helpers.spec.ts +0 -42
- package/source/hooks/chat-handler/utils/message-helpers.tsx +0 -36
- package/source/hooks/chat-handler/utils/tool-filters.spec.ts +0 -109
- package/source/hooks/chat-handler/utils/tool-filters.ts +0 -64
- package/source/hooks/useAppHandlers.tsx +0 -291
- package/source/hooks/useAppInitialization.tsx +0 -422
- package/source/hooks/useAppState.tsx +0 -311
- package/source/hooks/useDirectoryTrust.tsx +0 -98
- package/source/hooks/useInputState.ts +0 -414
- package/source/hooks/useModeHandlers.tsx +0 -302
- package/source/hooks/useNonInteractiveMode.ts +0 -140
- package/source/hooks/useTerminalWidth.tsx +0 -81
- package/source/hooks/useTheme.ts +0 -18
- package/source/hooks/useToolHandler.tsx +0 -349
- package/source/hooks/useUIState.ts +0 -61
- package/source/init/agents-template-generator.ts +0 -421
- package/source/init/existing-rules-extractor.ts +0 -319
- package/source/init/file-scanner.spec.ts +0 -227
- package/source/init/file-scanner.ts +0 -238
- package/source/init/framework-detector.ts +0 -382
- package/source/init/language-detector.ts +0 -269
- package/source/init/project-analyzer.spec.ts +0 -231
- package/source/init/project-analyzer.ts +0 -458
- package/source/lsp/index.ts +0 -31
- package/source/lsp/lsp-client.spec.ts +0 -508
- package/source/lsp/lsp-client.ts +0 -487
- package/source/lsp/lsp-manager.spec.ts +0 -477
- package/source/lsp/lsp-manager.ts +0 -419
- package/source/lsp/protocol.spec.ts +0 -502
- package/source/lsp/protocol.ts +0 -360
- package/source/lsp/server-discovery.spec.ts +0 -654
- package/source/lsp/server-discovery.ts +0 -515
- package/source/markdown-parser/html-entities.spec.ts +0 -88
- package/source/markdown-parser/html-entities.ts +0 -45
- package/source/markdown-parser/index.spec.ts +0 -281
- package/source/markdown-parser/index.ts +0 -126
- package/source/markdown-parser/table-parser.spec.ts +0 -133
- package/source/markdown-parser/table-parser.ts +0 -114
- package/source/markdown-parser/utils.spec.ts +0 -70
- package/source/markdown-parser/utils.ts +0 -13
- package/source/mcp/mcp-client.spec.ts +0 -81
- package/source/mcp/mcp-client.ts +0 -625
- package/source/mcp/transport-factory.spec.ts +0 -406
- package/source/mcp/transport-factory.ts +0 -312
- package/source/message-handler.ts +0 -67
- package/source/model-database/database-engine.spec.ts +0 -494
- package/source/model-database/database-engine.ts +0 -50
- package/source/model-database/model-database.spec.ts +0 -363
- package/source/model-database/model-database.ts +0 -91
- package/source/model-database/model-engine.spec.ts +0 -447
- package/source/model-database/model-engine.ts +0 -65
- package/source/model-database/model-fetcher.spec.ts +0 -583
- package/source/model-database/model-fetcher.ts +0 -330
- package/source/models/index.ts +0 -1
- package/source/models/models-cache.spec.ts +0 -214
- package/source/models/models-cache.ts +0 -78
- package/source/models/models-dev-client.spec.ts +0 -379
- package/source/models/models-dev-client.ts +0 -329
- package/source/models/models-types.ts +0 -68
- package/source/prompt-history.ts +0 -155
- package/source/security/command-injection.spec.ts +0 -240
- package/source/services/checkpoint-manager.spec.ts +0 -523
- package/source/services/checkpoint-manager.ts +0 -466
- package/source/services/file-snapshot.spec.ts +0 -569
- package/source/services/file-snapshot.ts +0 -220
- package/source/test-utils/render-with-theme.tsx +0 -48
- package/source/tokenization/index.ts +0 -1
- package/source/tokenization/tokenizer-factory.spec.ts +0 -170
- package/source/tokenization/tokenizer-factory.ts +0 -125
- package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +0 -200
- package/source/tokenization/tokenizers/anthropic-tokenizer.ts +0 -43
- package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +0 -236
- package/source/tokenization/tokenizers/fallback-tokenizer.ts +0 -26
- package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +0 -224
- package/source/tokenization/tokenizers/llama-tokenizer.ts +0 -41
- package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +0 -184
- package/source/tokenization/tokenizers/openai-tokenizer.ts +0 -57
- package/source/tool-calling/index.ts +0 -5
- package/source/tool-calling/json-parser.spec.ts +0 -639
- package/source/tool-calling/json-parser.ts +0 -247
- package/source/tool-calling/tool-parser.spec.ts +0 -395
- package/source/tool-calling/tool-parser.ts +0 -120
- package/source/tool-calling/xml-parser.spec.ts +0 -662
- package/source/tool-calling/xml-parser.ts +0 -289
- package/source/tools/execute-bash.spec.tsx +0 -353
- package/source/tools/execute-bash.tsx +0 -219
- package/source/tools/execute-function.spec.ts +0 -130
- package/source/tools/fetch-url.spec.tsx +0 -342
- package/source/tools/fetch-url.tsx +0 -172
- package/source/tools/find-files.spec.tsx +0 -924
- package/source/tools/find-files.tsx +0 -293
- package/source/tools/index.ts +0 -102
- package/source/tools/lsp-get-diagnostics.tsx +0 -192
- package/source/tools/needs-approval.spec.ts +0 -282
- package/source/tools/read-file.spec.tsx +0 -801
- package/source/tools/read-file.tsx +0 -387
- package/source/tools/search-file-contents.spec.tsx +0 -1273
- package/source/tools/search-file-contents.tsx +0 -293
- package/source/tools/string-replace.spec.tsx +0 -730
- package/source/tools/string-replace.tsx +0 -548
- package/source/tools/tool-manager.ts +0 -210
- package/source/tools/tool-registry.spec.ts +0 -415
- package/source/tools/tool-registry.ts +0 -228
- package/source/tools/web-search.tsx +0 -223
- package/source/tools/write-file.spec.tsx +0 -559
- package/source/tools/write-file.tsx +0 -228
- package/source/types/app.ts +0 -37
- package/source/types/checkpoint.ts +0 -48
- package/source/types/commands.ts +0 -46
- package/source/types/components.ts +0 -27
- package/source/types/config.ts +0 -103
- package/source/types/core-connection-status.spec.ts +0 -67
- package/source/types/core.ts +0 -181
- package/source/types/hooks.ts +0 -50
- package/source/types/index.ts +0 -12
- package/source/types/markdown-parser.ts +0 -11
- package/source/types/mcp.ts +0 -52
- package/source/types/system.ts +0 -16
- package/source/types/tokenization.ts +0 -41
- package/source/types/ui.ts +0 -40
- package/source/types/usage.ts +0 -58
- package/source/types/utils.ts +0 -16
- package/source/usage/calculator.spec.ts +0 -385
- package/source/usage/calculator.ts +0 -104
- package/source/usage/storage.spec.ts +0 -703
- package/source/usage/storage.ts +0 -238
- package/source/usage/tracker.spec.ts +0 -456
- package/source/usage/tracker.ts +0 -102
- package/source/utils/atomic-deletion.spec.ts +0 -194
- package/source/utils/atomic-deletion.ts +0 -127
- package/source/utils/bounded-map.spec.ts +0 -300
- package/source/utils/bounded-map.ts +0 -193
- package/source/utils/checkpoint-utils.spec.ts +0 -222
- package/source/utils/checkpoint-utils.ts +0 -92
- package/source/utils/error-formatter.spec.ts +0 -169
- package/source/utils/error-formatter.ts +0 -194
- package/source/utils/file-autocomplete.spec.ts +0 -173
- package/source/utils/file-autocomplete.ts +0 -196
- package/source/utils/file-cache.spec.ts +0 -309
- package/source/utils/file-cache.ts +0 -195
- package/source/utils/file-content-loader.spec.ts +0 -180
- package/source/utils/file-content-loader.ts +0 -179
- package/source/utils/file-mention-handler.spec.ts +0 -261
- package/source/utils/file-mention-handler.ts +0 -84
- package/source/utils/file-mention-parser.spec.ts +0 -182
- package/source/utils/file-mention-parser.ts +0 -170
- package/source/utils/fuzzy-matching.spec.ts +0 -149
- package/source/utils/fuzzy-matching.ts +0 -146
- package/source/utils/indentation-normalizer.spec.ts +0 -216
- package/source/utils/indentation-normalizer.ts +0 -76
- package/source/utils/installation-detector.spec.ts +0 -178
- package/source/utils/installation-detector.ts +0 -153
- package/source/utils/logging/config.spec.ts +0 -311
- package/source/utils/logging/config.ts +0 -210
- package/source/utils/logging/console-facade.spec.ts +0 -184
- package/source/utils/logging/console-facade.ts +0 -384
- package/source/utils/logging/correlation.spec.ts +0 -679
- package/source/utils/logging/correlation.ts +0 -474
- package/source/utils/logging/formatters.spec.ts +0 -464
- package/source/utils/logging/formatters.ts +0 -207
- package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +0 -93
- package/source/utils/logging/health-monitor/alerts/alert-manager.ts +0 -79
- package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/configuration-check.ts +0 -43
- package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/logging-check.ts +0 -58
- package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +0 -100
- package/source/utils/logging/health-monitor/checks/memory-check.ts +0 -78
- package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/performance-check.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.ts +0 -76
- package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +0 -70
- package/source/utils/logging/health-monitor/core/health-check-runner.ts +0 -138
- package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +0 -58
- package/source/utils/logging/health-monitor/core/health-monitor.ts +0 -344
- package/source/utils/logging/health-monitor/core/scoring.spec.ts +0 -65
- package/source/utils/logging/health-monitor/core/scoring.ts +0 -91
- package/source/utils/logging/health-monitor/index.ts +0 -15
- package/source/utils/logging/health-monitor/instances.ts +0 -48
- package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +0 -141
- package/source/utils/logging/health-monitor/middleware/http-middleware.ts +0 -75
- package/source/utils/logging/health-monitor/types.ts +0 -126
- package/source/utils/logging/index.spec.ts +0 -284
- package/source/utils/logging/index.ts +0 -236
- package/source/utils/logging/integration.spec.ts +0 -441
- package/source/utils/logging/log-method-factory.spec.ts +0 -573
- package/source/utils/logging/log-method-factory.ts +0 -233
- package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +0 -277
- package/source/utils/logging/log-query/aggregation/aggregator.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.ts +0 -47
- package/source/utils/logging/log-query/index.ts +0 -23
- package/source/utils/logging/log-query/query/filter-predicates.spec.ts +0 -247
- package/source/utils/logging/log-query/query/filter-predicates.ts +0 -154
- package/source/utils/logging/log-query/query/query-builder.spec.ts +0 -182
- package/source/utils/logging/log-query/query/query-builder.ts +0 -151
- package/source/utils/logging/log-query/query/query-engine.spec.ts +0 -214
- package/source/utils/logging/log-query/query/query-engine.ts +0 -45
- package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +0 -143
- package/source/utils/logging/log-query/storage/circular-buffer.ts +0 -75
- package/source/utils/logging/log-query/storage/index-manager.spec.ts +0 -150
- package/source/utils/logging/log-query/storage/index-manager.ts +0 -71
- package/source/utils/logging/log-query/storage/log-storage.spec.ts +0 -257
- package/source/utils/logging/log-query/storage/log-storage.ts +0 -80
- package/source/utils/logging/log-query/types.ts +0 -163
- package/source/utils/logging/log-query/utils/helpers.spec.ts +0 -263
- package/source/utils/logging/log-query/utils/helpers.ts +0 -72
- package/source/utils/logging/log-query/utils/sorting.spec.ts +0 -182
- package/source/utils/logging/log-query/utils/sorting.ts +0 -61
- package/source/utils/logging/logger-provider.spec.ts +0 -262
- package/source/utils/logging/logger-provider.ts +0 -362
- package/source/utils/logging/performance.spec.ts +0 -209
- package/source/utils/logging/performance.ts +0 -757
- package/source/utils/logging/pino-logger.spec.ts +0 -425
- package/source/utils/logging/pino-logger.ts +0 -514
- package/source/utils/logging/redaction.spec.ts +0 -490
- package/source/utils/logging/redaction.ts +0 -267
- package/source/utils/logging/request-tracker.spec.ts +0 -1198
- package/source/utils/logging/request-tracker.ts +0 -803
- package/source/utils/logging/transports.spec.ts +0 -505
- package/source/utils/logging/transports.ts +0 -305
- package/source/utils/logging/types.ts +0 -216
- package/source/utils/message-builder.spec.ts +0 -179
- package/source/utils/message-builder.ts +0 -101
- package/source/utils/message-queue.tsx +0 -486
- package/source/utils/paste-detection.spec.ts +0 -69
- package/source/utils/paste-detection.ts +0 -124
- package/source/utils/paste-roundtrip.spec.ts +0 -442
- package/source/utils/paste-utils.spec.ts +0 -128
- package/source/utils/paste-utils.ts +0 -52
- package/source/utils/programming-language-helper.spec.ts +0 -74
- package/source/utils/programming-language-helper.ts +0 -32
- package/source/utils/prompt-assembly.spec.ts +0 -221
- package/source/utils/prompt-processor.ts +0 -173
- package/source/utils/tool-args-parser.spec.ts +0 -136
- package/source/utils/tool-args-parser.ts +0 -54
- package/source/utils/tool-cancellation.spec.ts +0 -230
- package/source/utils/tool-cancellation.ts +0 -28
- package/source/utils/tool-result-display.spec.tsx +0 -469
- package/source/utils/tool-result-display.tsx +0 -90
- package/source/utils/update-checker.spec.ts +0 -383
- package/source/utils/update-checker.ts +0 -183
- package/source/wizard/config-wizard.spec.tsx +0 -103
- package/source/wizard/config-wizard.tsx +0 -382
- package/source/wizard/steps/location-step.spec.tsx +0 -186
- package/source/wizard/steps/location-step.tsx +0 -147
- package/source/wizard/steps/mcp-step.spec.tsx +0 -607
- package/source/wizard/steps/mcp-step.tsx +0 -632
- package/source/wizard/steps/provider-step.spec.tsx +0 -342
- package/source/wizard/steps/provider-step.tsx +0 -957
- package/source/wizard/steps/summary-step.spec.tsx +0 -749
- package/source/wizard/steps/summary-step.tsx +0 -228
- package/source/wizard/templates/mcp-templates.spec.ts +0 -613
- package/source/wizard/templates/mcp-templates.ts +0 -570
- package/source/wizard/templates/provider-templates.spec.ts +0 -152
- package/source/wizard/templates/provider-templates.ts +0 -485
- package/source/wizard/utils/fetch-cloud-models.spec.ts +0 -428
- package/source/wizard/utils/fetch-cloud-models.ts +0 -223
- package/source/wizard/utils/fetch-local-models.spec.ts +0 -297
- package/source/wizard/utils/fetch-local-models.ts +0 -192
- package/source/wizard/validation-array.spec.ts +0 -264
- package/source/wizard/validation.spec.ts +0 -373
- package/source/wizard/validation.ts +0 -232
package/source/mcp/mcp-client.ts
DELETED
|
@@ -1,625 +0,0 @@
|
|
|
1
|
-
import {Client} from '@modelcontextprotocol/sdk/client/index.js';
|
|
2
|
-
import {StdioClientTransport} from '@modelcontextprotocol/sdk/client/stdio.js';
|
|
3
|
-
import {StreamableHTTPClientTransport} from '@modelcontextprotocol/sdk/client/streamableHttp.js';
|
|
4
|
-
import {WebSocketClientTransport} from '@modelcontextprotocol/sdk/client/websocket.js';
|
|
5
|
-
|
|
6
|
-
// Union type for all supported client transports
|
|
7
|
-
type ClientTransport =
|
|
8
|
-
| StdioClientTransport
|
|
9
|
-
| WebSocketClientTransport
|
|
10
|
-
| StreamableHTTPClientTransport;
|
|
11
|
-
import {getCurrentMode} from '@/context/mode-context';
|
|
12
|
-
import type {AISDKCoreTool, Tool, ToolParameterSchema} from '@/types/index';
|
|
13
|
-
import {jsonSchema} from '@/types/index';
|
|
14
|
-
import {
|
|
15
|
-
endMetrics,
|
|
16
|
-
formatMemoryUsage,
|
|
17
|
-
generateCorrelationId,
|
|
18
|
-
getLogger,
|
|
19
|
-
startMetrics,
|
|
20
|
-
withNewCorrelationContext,
|
|
21
|
-
} from '@/utils/logging';
|
|
22
|
-
import {dynamicTool} from 'ai';
|
|
23
|
-
import {TransportFactory} from './transport-factory.js';
|
|
24
|
-
|
|
25
|
-
import type {MCPInitResult, MCPServer, MCPTool} from '@/types/index';
|
|
26
|
-
|
|
27
|
-
export class MCPClient {
|
|
28
|
-
private clients: Map<string, Client> = new Map();
|
|
29
|
-
private transports: Map<string, ClientTransport> = new Map();
|
|
30
|
-
private serverTools: Map<string, MCPTool[]> = new Map();
|
|
31
|
-
private serverConfigs: Map<string, MCPServer> = new Map();
|
|
32
|
-
private isConnected: boolean = false;
|
|
33
|
-
private logger = getLogger();
|
|
34
|
-
|
|
35
|
-
constructor() {
|
|
36
|
-
this.logger.debug('MCP client initialized');
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Ensures backward compatibility for old MCP server configurations
|
|
41
|
-
* by adding default transport type for existing configurations
|
|
42
|
-
*/
|
|
43
|
-
private normalizeServerConfig(server: MCPServer): MCPServer {
|
|
44
|
-
// If no transport is specified, default to 'stdio' for backward compatibility
|
|
45
|
-
if (!server.transport) {
|
|
46
|
-
return {
|
|
47
|
-
...server,
|
|
48
|
-
transport: 'stdio',
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
return server;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
async connectToServer(server: MCPServer): Promise<void> {
|
|
55
|
-
const correlationId = generateCorrelationId();
|
|
56
|
-
const metrics = startMetrics();
|
|
57
|
-
|
|
58
|
-
return await withNewCorrelationContext(async () => {
|
|
59
|
-
// Normalize server configuration for backward compatibility
|
|
60
|
-
const normalizedServer = this.normalizeServerConfig(server);
|
|
61
|
-
|
|
62
|
-
this.logger.info('Connecting to MCP server', {
|
|
63
|
-
serverName: normalizedServer.name,
|
|
64
|
-
transport: normalizedServer.transport,
|
|
65
|
-
hasUrl: !!normalizedServer.url,
|
|
66
|
-
hasCommand: !!normalizedServer.command,
|
|
67
|
-
correlationId,
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// Validate server configuration
|
|
71
|
-
const validation =
|
|
72
|
-
TransportFactory.validateServerConfig(normalizedServer);
|
|
73
|
-
if (!validation.valid) {
|
|
74
|
-
const finalMetrics = endMetrics(metrics);
|
|
75
|
-
this.logger.error('MCP server configuration validation failed', {
|
|
76
|
-
serverName: normalizedServer.name,
|
|
77
|
-
errors: validation.errors,
|
|
78
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
79
|
-
correlationId,
|
|
80
|
-
});
|
|
81
|
-
throw new Error(
|
|
82
|
-
`Invalid MCP server configuration for "${
|
|
83
|
-
normalizedServer.name
|
|
84
|
-
}": ${validation.errors.join(', ')}`,
|
|
85
|
-
);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
try {
|
|
89
|
-
// Create transport using the factory
|
|
90
|
-
const transport = TransportFactory.createTransport(normalizedServer);
|
|
91
|
-
|
|
92
|
-
this.logger.debug('MCP transport created', {
|
|
93
|
-
serverName: normalizedServer.name,
|
|
94
|
-
transportType: normalizedServer.transport,
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
// Create and connect client
|
|
98
|
-
const client = new Client({
|
|
99
|
-
name: 'coder-mcp-client',
|
|
100
|
-
version: '1.0.0',
|
|
101
|
-
});
|
|
102
|
-
|
|
103
|
-
this.logger.debug('MCP client created, attempting connection', {
|
|
104
|
-
serverName: normalizedServer.name,
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
await client.connect(transport);
|
|
108
|
-
|
|
109
|
-
this.logger.info('MCP server connected successfully', {
|
|
110
|
-
serverName: normalizedServer.name,
|
|
111
|
-
transport: normalizedServer.transport,
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
// Store client, transport, and server config
|
|
115
|
-
this.clients.set(normalizedServer.name, client);
|
|
116
|
-
this.transports.set(normalizedServer.name, transport);
|
|
117
|
-
this.serverConfigs.set(normalizedServer.name, normalizedServer);
|
|
118
|
-
|
|
119
|
-
// List available tools from this server
|
|
120
|
-
const toolsResult = await client.listTools();
|
|
121
|
-
const tools: MCPTool[] = toolsResult.tools.map(tool => ({
|
|
122
|
-
name: tool.name,
|
|
123
|
-
description: tool.description || undefined,
|
|
124
|
-
inputSchema: tool.inputSchema,
|
|
125
|
-
serverName: normalizedServer.name,
|
|
126
|
-
}));
|
|
127
|
-
|
|
128
|
-
this.serverTools.set(normalizedServer.name, tools);
|
|
129
|
-
|
|
130
|
-
const finalMetrics = endMetrics(metrics);
|
|
131
|
-
|
|
132
|
-
this.logger.info('MCP server connection completed', {
|
|
133
|
-
serverName: normalizedServer.name,
|
|
134
|
-
toolCount: tools.length,
|
|
135
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
136
|
-
memoryDelta: formatMemoryUsage(
|
|
137
|
-
finalMetrics.memoryUsage || process.memoryUsage(),
|
|
138
|
-
),
|
|
139
|
-
correlationId,
|
|
140
|
-
});
|
|
141
|
-
} catch (error) {
|
|
142
|
-
const finalMetrics = endMetrics(metrics);
|
|
143
|
-
this.logger.error('Failed to connect to MCP server', {
|
|
144
|
-
serverName: normalizedServer.name,
|
|
145
|
-
transport: normalizedServer.transport,
|
|
146
|
-
error: error instanceof Error ? error.message : error,
|
|
147
|
-
errorName: error instanceof Error ? error.name : 'Unknown',
|
|
148
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
149
|
-
memoryDelta: formatMemoryUsage(
|
|
150
|
-
finalMetrics.memoryUsage || process.memoryUsage(),
|
|
151
|
-
),
|
|
152
|
-
correlationId,
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
throw error;
|
|
156
|
-
}
|
|
157
|
-
}, correlationId);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
async connectToServers(
|
|
161
|
-
servers: MCPServer[],
|
|
162
|
-
onProgress?: (result: MCPInitResult) => void,
|
|
163
|
-
): Promise<MCPInitResult[]> {
|
|
164
|
-
const results: MCPInitResult[] = [];
|
|
165
|
-
const correlationId = generateCorrelationId();
|
|
166
|
-
const metrics = startMetrics();
|
|
167
|
-
|
|
168
|
-
this.logger.info('Starting batch MCP server connections', {
|
|
169
|
-
serverCount: servers.length,
|
|
170
|
-
serverNames: servers.map(s => this.normalizeServerConfig(s).name),
|
|
171
|
-
correlationId,
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
return await withNewCorrelationContext(async () => {
|
|
175
|
-
// Connect to servers in parallel for better performance
|
|
176
|
-
const connectionPromises = servers.map(async server => {
|
|
177
|
-
try {
|
|
178
|
-
// Normalize server configuration for backward compatibility
|
|
179
|
-
const normalizedServer = this.normalizeServerConfig(server);
|
|
180
|
-
|
|
181
|
-
await this.connectToServer(normalizedServer);
|
|
182
|
-
const tools = this.serverTools.get(normalizedServer.name) || [];
|
|
183
|
-
const result: MCPInitResult = {
|
|
184
|
-
serverName: normalizedServer.name,
|
|
185
|
-
success: true,
|
|
186
|
-
toolCount: tools.length,
|
|
187
|
-
};
|
|
188
|
-
results.push(result);
|
|
189
|
-
|
|
190
|
-
this.logger.debug('MCP server connection successful in batch', {
|
|
191
|
-
serverName: normalizedServer.name,
|
|
192
|
-
toolCount: tools.length,
|
|
193
|
-
correlationId,
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
onProgress?.(result);
|
|
197
|
-
return result;
|
|
198
|
-
} catch (error) {
|
|
199
|
-
const normalizedServer = this.normalizeServerConfig(server);
|
|
200
|
-
const result: MCPInitResult = {
|
|
201
|
-
serverName: normalizedServer.name,
|
|
202
|
-
success: false,
|
|
203
|
-
error: error instanceof Error ? error.message : String(error),
|
|
204
|
-
};
|
|
205
|
-
|
|
206
|
-
this.logger.error('MCP server connection failed in batch', {
|
|
207
|
-
serverName: normalizedServer.name,
|
|
208
|
-
error: result.error,
|
|
209
|
-
errorName: error instanceof Error ? error.name : 'Unknown',
|
|
210
|
-
correlationId,
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
results.push(result);
|
|
214
|
-
onProgress?.(result);
|
|
215
|
-
return result;
|
|
216
|
-
}
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
// Wait for all connections to complete
|
|
220
|
-
await Promise.all(connectionPromises);
|
|
221
|
-
|
|
222
|
-
const finalMetrics = endMetrics(metrics);
|
|
223
|
-
const successfulConnections = results.filter(r => r.success).length;
|
|
224
|
-
const failedConnections = results.length - successfulConnections;
|
|
225
|
-
|
|
226
|
-
this.logger.info('Batch MCP server connections completed', {
|
|
227
|
-
totalServers: servers.length,
|
|
228
|
-
successfulConnections,
|
|
229
|
-
failedConnections,
|
|
230
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
231
|
-
correlationId,
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
this.isConnected = true;
|
|
235
|
-
return results;
|
|
236
|
-
}, correlationId);
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
getAllTools(): Tool[] {
|
|
240
|
-
const tools: Tool[] = [];
|
|
241
|
-
|
|
242
|
-
this.logger.debug('Building all tools registry from MCP servers', {
|
|
243
|
-
serverCount: this.serverTools.size,
|
|
244
|
-
totalToolsAvailable: Array.from(this.serverTools.values()).reduce(
|
|
245
|
-
(sum, tools) => sum + tools.length,
|
|
246
|
-
0,
|
|
247
|
-
),
|
|
248
|
-
});
|
|
249
|
-
|
|
250
|
-
for (const [serverName, serverTools] of this.serverTools.entries()) {
|
|
251
|
-
this.logger.debug('Processing tools from MCP server', {
|
|
252
|
-
serverName,
|
|
253
|
-
toolCount: serverTools.length,
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
for (const mcpTool of serverTools) {
|
|
257
|
-
// Convert MCP tool to coder Tool format
|
|
258
|
-
// Use the original tool name for better model compatibility
|
|
259
|
-
const schema = mcpTool.inputSchema as
|
|
260
|
-
| {
|
|
261
|
-
type?: string;
|
|
262
|
-
properties?: Record<string, unknown>;
|
|
263
|
-
required?: string[];
|
|
264
|
-
}
|
|
265
|
-
| undefined;
|
|
266
|
-
|
|
267
|
-
const tool: Tool = {
|
|
268
|
-
type: 'function',
|
|
269
|
-
function: {
|
|
270
|
-
name: mcpTool.name,
|
|
271
|
-
description: mcpTool.description
|
|
272
|
-
? `[MCP:${serverName}] ${mcpTool.description}`
|
|
273
|
-
: `MCP tool from ${serverName}`,
|
|
274
|
-
parameters: {
|
|
275
|
-
type: 'object',
|
|
276
|
-
properties: (schema?.properties || {}) as Record<
|
|
277
|
-
string,
|
|
278
|
-
ToolParameterSchema
|
|
279
|
-
>,
|
|
280
|
-
required: schema?.required || [],
|
|
281
|
-
},
|
|
282
|
-
},
|
|
283
|
-
};
|
|
284
|
-
tools.push(tool);
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
return tools;
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
/**
|
|
292
|
-
* Get all MCP tools as AI SDK native CoreTool format
|
|
293
|
-
* Converts MCP tool schemas to AI SDK's tool() format
|
|
294
|
-
*/
|
|
295
|
-
getNativeToolsRegistry(): Record<string, AISDKCoreTool> {
|
|
296
|
-
const nativeTools: Record<string, AISDKCoreTool> = {};
|
|
297
|
-
|
|
298
|
-
for (const [serverName, serverTools] of this.serverTools.entries()) {
|
|
299
|
-
for (const mcpTool of serverTools) {
|
|
300
|
-
// dynamicTool is more explicit about unknown types compared to tool()
|
|
301
|
-
// MCP schemas come from external servers and are not known at compile time
|
|
302
|
-
const toolName = mcpTool.name;
|
|
303
|
-
const coreTool = dynamicTool({
|
|
304
|
-
description: mcpTool.description
|
|
305
|
-
? `[MCP:${serverName}] ${mcpTool.description}`
|
|
306
|
-
: `MCP tool from ${serverName}`,
|
|
307
|
-
inputSchema: jsonSchema<Record<string, unknown>>(
|
|
308
|
-
(mcpTool.inputSchema as unknown) || {type: 'object'},
|
|
309
|
-
),
|
|
310
|
-
// Medium risk: MCP tools require approval except in auto-accept mode
|
|
311
|
-
needsApproval: () => {
|
|
312
|
-
const mode = getCurrentMode();
|
|
313
|
-
return mode !== 'auto-accept'; // true in normal/plan, false in auto-accept
|
|
314
|
-
},
|
|
315
|
-
execute: async (input, _options) => {
|
|
316
|
-
// dynamicTool passes 'input' as unknown, validate at runtime
|
|
317
|
-
return await this.callTool(
|
|
318
|
-
toolName,
|
|
319
|
-
input as Record<string, unknown>,
|
|
320
|
-
);
|
|
321
|
-
},
|
|
322
|
-
});
|
|
323
|
-
|
|
324
|
-
nativeTools[mcpTool.name] = coreTool;
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
return nativeTools;
|
|
329
|
-
}
|
|
330
|
-
getToolMapping(): Map<string, {serverName: string; originalName: string}> {
|
|
331
|
-
const mapping = new Map<
|
|
332
|
-
string,
|
|
333
|
-
{serverName: string; originalName: string}
|
|
334
|
-
>();
|
|
335
|
-
|
|
336
|
-
for (const [serverName, serverTools] of this.serverTools.entries()) {
|
|
337
|
-
for (const mcpTool of serverTools) {
|
|
338
|
-
mapping.set(mcpTool.name, {
|
|
339
|
-
serverName,
|
|
340
|
-
originalName: mcpTool.name,
|
|
341
|
-
});
|
|
342
|
-
}
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
return mapping;
|
|
346
|
-
}
|
|
347
|
-
|
|
348
|
-
/**
|
|
349
|
-
* Get all MCP tools as entries with handlers for easy registration
|
|
350
|
-
* Each entry contains the native AI SDK tool and its handler function
|
|
351
|
-
*
|
|
352
|
-
* the AI SDK tool definition and the corresponding handler function.
|
|
353
|
-
* This enables cleaner integration with ToolManager.
|
|
354
|
-
*
|
|
355
|
-
* @returns Array of tool entries with name, AI SDK tool, and handler function
|
|
356
|
-
*/
|
|
357
|
-
getToolEntries(): Array<{
|
|
358
|
-
name: string;
|
|
359
|
-
tool: AISDKCoreTool;
|
|
360
|
-
handler: (args: Record<string, unknown>) => Promise<string>;
|
|
361
|
-
}> {
|
|
362
|
-
const entries: Array<{
|
|
363
|
-
name: string;
|
|
364
|
-
tool: AISDKCoreTool;
|
|
365
|
-
handler: (args: Record<string, unknown>) => Promise<string>;
|
|
366
|
-
}> = [];
|
|
367
|
-
|
|
368
|
-
// Get native tools once to avoid redundant calls
|
|
369
|
-
const nativeTools = this.getNativeToolsRegistry();
|
|
370
|
-
|
|
371
|
-
for (const [, serverTools] of this.serverTools.entries()) {
|
|
372
|
-
for (const mcpTool of serverTools) {
|
|
373
|
-
const toolName = mcpTool.name;
|
|
374
|
-
|
|
375
|
-
// Get the AI SDK native tool
|
|
376
|
-
const coreTool = nativeTools[toolName];
|
|
377
|
-
|
|
378
|
-
if (coreTool) {
|
|
379
|
-
// Create handler that calls this tool
|
|
380
|
-
const handler = async (args: Record<string, unknown>) => {
|
|
381
|
-
return this.callTool(toolName, args);
|
|
382
|
-
};
|
|
383
|
-
|
|
384
|
-
entries.push({
|
|
385
|
-
name: toolName,
|
|
386
|
-
tool: coreTool,
|
|
387
|
-
handler,
|
|
388
|
-
});
|
|
389
|
-
}
|
|
390
|
-
}
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
return entries;
|
|
394
|
-
}
|
|
395
|
-
|
|
396
|
-
async callTool(
|
|
397
|
-
toolName: string,
|
|
398
|
-
args: Record<string, unknown>,
|
|
399
|
-
): Promise<string> {
|
|
400
|
-
// First, try to find which server has this tool
|
|
401
|
-
const toolMapping = this.getToolMapping();
|
|
402
|
-
const mapping = toolMapping.get(toolName);
|
|
403
|
-
|
|
404
|
-
if (!mapping) {
|
|
405
|
-
// Fallback: try parsing as prefixed name (mcp_serverName_toolName) for backward compatibility
|
|
406
|
-
const parts = toolName.split('_');
|
|
407
|
-
if (parts.length >= 3 && parts[0] === 'mcp' && parts[1]) {
|
|
408
|
-
const serverName = parts[1];
|
|
409
|
-
const originalToolName = parts.slice(2).join('_');
|
|
410
|
-
const client = this.clients.get(serverName);
|
|
411
|
-
if (client) {
|
|
412
|
-
return this.executeToolCall(client, originalToolName, args);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
throw new Error(`MCP tool not found: ${toolName}`);
|
|
416
|
-
}
|
|
417
|
-
|
|
418
|
-
const client = this.clients.get(mapping.serverName);
|
|
419
|
-
if (!client) {
|
|
420
|
-
throw new Error(
|
|
421
|
-
`No MCP client connected for server: ${mapping.serverName}`,
|
|
422
|
-
);
|
|
423
|
-
}
|
|
424
|
-
|
|
425
|
-
return this.executeToolCall(client, mapping.originalName, args);
|
|
426
|
-
}
|
|
427
|
-
|
|
428
|
-
private async executeToolCall(
|
|
429
|
-
client: Client,
|
|
430
|
-
toolName: string,
|
|
431
|
-
args: Record<string, unknown>,
|
|
432
|
-
): Promise<string> {
|
|
433
|
-
const correlationId = generateCorrelationId();
|
|
434
|
-
const metrics = startMetrics();
|
|
435
|
-
|
|
436
|
-
return await withNewCorrelationContext(async () => {
|
|
437
|
-
this.logger.info('Executing MCP tool', {
|
|
438
|
-
toolName,
|
|
439
|
-
argumentCount: Object.keys(args).length,
|
|
440
|
-
hasArguments: Object.keys(args).length > 0,
|
|
441
|
-
correlationId,
|
|
442
|
-
});
|
|
443
|
-
|
|
444
|
-
try {
|
|
445
|
-
const result = await client.callTool({
|
|
446
|
-
name: toolName,
|
|
447
|
-
arguments: args,
|
|
448
|
-
});
|
|
449
|
-
|
|
450
|
-
this.logger.debug('MCP tool executed successfully', {
|
|
451
|
-
toolName,
|
|
452
|
-
hasContent: !!result.content,
|
|
453
|
-
contentLength: Array.isArray(result.content)
|
|
454
|
-
? result.content.length
|
|
455
|
-
: 0,
|
|
456
|
-
correlationId,
|
|
457
|
-
});
|
|
458
|
-
|
|
459
|
-
// Convert result content to string
|
|
460
|
-
if (
|
|
461
|
-
result.content &&
|
|
462
|
-
Array.isArray(result.content) &&
|
|
463
|
-
result.content.length > 0
|
|
464
|
-
) {
|
|
465
|
-
const content = result.content[0] as
|
|
466
|
-
| {type: 'text'; text?: string}
|
|
467
|
-
| Record<string, unknown>;
|
|
468
|
-
if ('type' in content && content.type === 'text') {
|
|
469
|
-
const textContent = content as {type: 'text'; text?: string};
|
|
470
|
-
const responseText = textContent.text || '';
|
|
471
|
-
|
|
472
|
-
const finalMetrics = endMetrics(metrics);
|
|
473
|
-
this.logger.info('MCP tool execution completed', {
|
|
474
|
-
toolName,
|
|
475
|
-
responseLength: responseText.length,
|
|
476
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
477
|
-
correlationId,
|
|
478
|
-
});
|
|
479
|
-
|
|
480
|
-
return responseText;
|
|
481
|
-
}
|
|
482
|
-
const jsonResponse = JSON.stringify(content);
|
|
483
|
-
|
|
484
|
-
const finalMetrics = endMetrics(metrics);
|
|
485
|
-
this.logger.info('MCP tool execution completed (JSON)', {
|
|
486
|
-
toolName,
|
|
487
|
-
responseLength: jsonResponse.length,
|
|
488
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
489
|
-
correlationId,
|
|
490
|
-
});
|
|
491
|
-
|
|
492
|
-
return jsonResponse;
|
|
493
|
-
}
|
|
494
|
-
|
|
495
|
-
const finalMetrics = endMetrics(metrics);
|
|
496
|
-
this.logger.info('MCP tool execution completed (no output)', {
|
|
497
|
-
toolName,
|
|
498
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
499
|
-
correlationId,
|
|
500
|
-
});
|
|
501
|
-
|
|
502
|
-
return 'Tool executed successfully (no output)';
|
|
503
|
-
} catch (error) {
|
|
504
|
-
const errorMessage =
|
|
505
|
-
error instanceof Error ? error.message : 'Unknown error';
|
|
506
|
-
const errorName = error instanceof Error ? error.name : 'Unknown';
|
|
507
|
-
|
|
508
|
-
const finalMetrics = endMetrics(metrics);
|
|
509
|
-
|
|
510
|
-
this.logger.error('MCP tool execution failed', {
|
|
511
|
-
toolName,
|
|
512
|
-
error: errorMessage,
|
|
513
|
-
errorName,
|
|
514
|
-
duration: `${finalMetrics.duration.toFixed(2)}ms`,
|
|
515
|
-
correlationId,
|
|
516
|
-
});
|
|
517
|
-
|
|
518
|
-
throw new Error(`MCP tool execution failed: ${errorMessage}`);
|
|
519
|
-
}
|
|
520
|
-
}, correlationId);
|
|
521
|
-
}
|
|
522
|
-
|
|
523
|
-
async disconnect(): Promise<void> {
|
|
524
|
-
const correlationId = generateCorrelationId();
|
|
525
|
-
const serverNames = Array.from(this.clients.keys());
|
|
526
|
-
|
|
527
|
-
if (serverNames.length === 0) {
|
|
528
|
-
this.logger.debug('No MCP servers to disconnect from');
|
|
529
|
-
return;
|
|
530
|
-
}
|
|
531
|
-
|
|
532
|
-
this.logger.info('Disconnecting from MCP servers', {
|
|
533
|
-
serverCount: serverNames.length,
|
|
534
|
-
serverNames,
|
|
535
|
-
correlationId,
|
|
536
|
-
});
|
|
537
|
-
|
|
538
|
-
return await withNewCorrelationContext(async () => {
|
|
539
|
-
let successfulDisconnections = 0;
|
|
540
|
-
let failedDisconnections = 0;
|
|
541
|
-
|
|
542
|
-
for (const [serverName, client] of this.clients.entries()) {
|
|
543
|
-
try {
|
|
544
|
-
await client.close();
|
|
545
|
-
successfulDisconnections++;
|
|
546
|
-
|
|
547
|
-
this.logger.info('Disconnected from MCP server successfully', {
|
|
548
|
-
serverName,
|
|
549
|
-
correlationId,
|
|
550
|
-
});
|
|
551
|
-
} catch (error) {
|
|
552
|
-
failedDisconnections++;
|
|
553
|
-
const errorMessage =
|
|
554
|
-
error instanceof Error ? error.message : 'Unknown error';
|
|
555
|
-
const errorName = error instanceof Error ? error.name : 'Unknown';
|
|
556
|
-
|
|
557
|
-
this.logger.error('Error disconnecting from MCP server', {
|
|
558
|
-
serverName,
|
|
559
|
-
error: errorMessage,
|
|
560
|
-
errorName,
|
|
561
|
-
correlationId,
|
|
562
|
-
});
|
|
563
|
-
}
|
|
564
|
-
}
|
|
565
|
-
|
|
566
|
-
this.clients.clear();
|
|
567
|
-
this.transports.clear();
|
|
568
|
-
this.serverTools.clear();
|
|
569
|
-
this.serverConfigs.clear();
|
|
570
|
-
this.isConnected = false;
|
|
571
|
-
|
|
572
|
-
this.logger.info('MCP client disconnection completed', {
|
|
573
|
-
totalServers: serverNames.length,
|
|
574
|
-
successfulDisconnections,
|
|
575
|
-
failedDisconnections,
|
|
576
|
-
correlationId,
|
|
577
|
-
});
|
|
578
|
-
}, correlationId);
|
|
579
|
-
}
|
|
580
|
-
|
|
581
|
-
getConnectedServers(): string[] {
|
|
582
|
-
return Array.from(this.clients.keys());
|
|
583
|
-
}
|
|
584
|
-
|
|
585
|
-
isServerConnected(serverName: string): boolean {
|
|
586
|
-
return this.clients.has(serverName);
|
|
587
|
-
}
|
|
588
|
-
|
|
589
|
-
getServerTools(serverName: string): MCPTool[] {
|
|
590
|
-
return this.serverTools.get(serverName) || [];
|
|
591
|
-
}
|
|
592
|
-
|
|
593
|
-
/**
|
|
594
|
-
* Gets server information including transport type and URL for remote servers
|
|
595
|
-
*/
|
|
596
|
-
getServerInfo(serverName: string):
|
|
597
|
-
| {
|
|
598
|
-
name: string;
|
|
599
|
-
transport: string;
|
|
600
|
-
url?: string;
|
|
601
|
-
toolCount: number;
|
|
602
|
-
connected: boolean;
|
|
603
|
-
description?: string;
|
|
604
|
-
tags?: string[];
|
|
605
|
-
}
|
|
606
|
-
| undefined {
|
|
607
|
-
const client = this.clients.get(serverName);
|
|
608
|
-
const serverConfig = this.serverConfigs.get(serverName);
|
|
609
|
-
const tools = this.serverTools.get(serverName) || [];
|
|
610
|
-
|
|
611
|
-
if (!client || !serverConfig) {
|
|
612
|
-
return undefined;
|
|
613
|
-
}
|
|
614
|
-
|
|
615
|
-
return {
|
|
616
|
-
name: serverName,
|
|
617
|
-
transport: serverConfig.transport,
|
|
618
|
-
url: serverConfig.url,
|
|
619
|
-
toolCount: tools.length,
|
|
620
|
-
connected: true,
|
|
621
|
-
description: serverConfig.description,
|
|
622
|
-
tags: serverConfig.tags,
|
|
623
|
-
};
|
|
624
|
-
}
|
|
625
|
-
}
|