imcp 0.1.7 → 0.1.8-dev
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/dist/cli/commands/install.js +1 -106
- package/dist/cli/commands/install.js.map +1 -0
- package/dist/cli/commands/list.js +1 -90
- package/dist/cli/commands/list.js.map +1 -0
- package/dist/cli/commands/pull.js +1 -16
- package/dist/cli/commands/pull.js.map +1 -0
- package/dist/cli/commands/serve.js +1 -33
- package/dist/cli/commands/serve.js.map +1 -0
- package/dist/cli/commands/uninstall.js +1 -46
- package/dist/cli/commands/uninstall.js.map +1 -0
- package/dist/cli/index.js +1 -65
- package/dist/cli/index.js.map +1 -0
- package/dist/core/installers/clients/BaseClientInstaller.js +1 -282
- package/dist/core/installers/clients/BaseClientInstaller.js.map +1 -0
- package/dist/core/installers/clients/ClientInstaller.js +1 -163
- package/dist/core/installers/clients/ClientInstaller.js.map +1 -0
- package/dist/core/installers/clients/ClientInstallerFactory.js +1 -36
- package/dist/core/installers/clients/ClientInstallerFactory.js.map +1 -0
- package/dist/core/installers/clients/ClineInstaller.js +1 -30
- package/dist/core/installers/clients/ClineInstaller.js.map +1 -0
- package/dist/core/installers/clients/ExtensionInstaller.js +1 -151
- package/dist/core/installers/clients/ExtensionInstaller.js.map +1 -0
- package/dist/core/installers/clients/GithubCopilotInstaller.js +1 -68
- package/dist/core/installers/clients/GithubCopilotInstaller.js.map +1 -0
- package/dist/core/installers/clients/MSRooCodeInstaller.js +1 -28
- package/dist/core/installers/clients/MSRooCodeInstaller.js.map +1 -0
- package/dist/core/installers/index.js +1 -8
- package/dist/core/installers/index.js.map +1 -0
- package/dist/core/installers/requirements/BaseInstaller.js +1 -56
- package/dist/core/installers/requirements/BaseInstaller.js.map +1 -0
- package/dist/core/installers/requirements/CommandInstaller.js +1 -213
- package/dist/core/installers/requirements/CommandInstaller.js.map +1 -0
- package/dist/core/installers/requirements/GeneralInstaller.js +1 -126
- package/dist/core/installers/requirements/GeneralInstaller.js.map +1 -0
- package/dist/core/installers/requirements/InstallerFactory.js +1 -99
- package/dist/core/installers/requirements/InstallerFactory.js.map +1 -0
- package/dist/core/installers/requirements/NpmInstaller.js +1 -235
- package/dist/core/installers/requirements/NpmInstaller.js.map +1 -0
- package/dist/core/installers/requirements/NugetInstaller.js +1 -188
- package/dist/core/installers/requirements/NugetInstaller.js.map +1 -0
- package/dist/core/installers/requirements/PipInstaller.js +1 -192
- package/dist/core/installers/requirements/PipInstaller.js.map +1 -0
- package/dist/core/installers/requirements/RequirementInstaller.js +1 -2
- package/dist/core/installers/requirements/RequirementInstaller.js.map +1 -0
- package/dist/core/loaders/ConfigurationLoader.js +1 -256
- package/dist/core/loaders/ConfigurationLoader.js.map +1 -0
- package/dist/core/loaders/ConfigurationProvider.js +1 -383
- package/dist/core/loaders/ConfigurationProvider.js.map +1 -0
- package/dist/core/loaders/InstallOperationManager.js +1 -310
- package/dist/core/loaders/InstallOperationManager.js.map +1 -0
- package/dist/core/loaders/ServerSchemaLoader.js +1 -108
- package/dist/core/loaders/ServerSchemaLoader.js.map +1 -0
- package/dist/core/loaders/ServerSchemaProvider.js +1 -89
- package/dist/core/loaders/ServerSchemaProvider.js.map +1 -0
- package/dist/core/loaders/SystemSettingsManager.js +1 -256
- package/dist/core/loaders/SystemSettingsManager.js.map +1 -0
- package/dist/core/metadatas/constants.js +1 -100
- package/dist/core/metadatas/constants.js.map +1 -0
- package/dist/core/metadatas/recordingConstants.js +1 -46
- package/dist/core/metadatas/recordingConstants.js.map +1 -0
- package/dist/core/metadatas/types.js +1 -15
- package/dist/core/metadatas/types.js.map +1 -0
- package/dist/core/onboard/FeedOnboardService.js +1 -422
- package/dist/core/onboard/FeedOnboardService.js.map +1 -0
- package/dist/core/onboard/OnboardProcessor.js +1 -333
- package/dist/core/onboard/OnboardProcessor.js.map +1 -0
- package/dist/core/onboard/OnboardStatus.js +1 -9
- package/dist/core/onboard/OnboardStatus.js.map +1 -0
- package/dist/core/onboard/OnboardStatusManager.js +1 -360
- package/dist/core/onboard/OnboardStatusManager.js.map +1 -0
- package/dist/core/validators/FeedValidator.js +1 -133
- package/dist/core/validators/FeedValidator.js.map +1 -0
- package/dist/core/validators/IServerValidator.js +1 -1
- package/dist/core/validators/IServerValidator.js.map +1 -0
- package/dist/core/validators/SSEServerValidator.js +1 -38
- package/dist/core/validators/SSEServerValidator.js.map +1 -0
- package/dist/core/validators/ServerValidatorFactory.js +1 -44
- package/dist/core/validators/ServerValidatorFactory.js.map +1 -0
- package/dist/core/validators/StdioServerValidator.js +1 -281
- package/dist/core/validators/StdioServerValidator.js.map +1 -0
- package/dist/index.js +1 -18
- package/dist/index.js.map +1 -0
- package/dist/services/InstallationService.js +1 -81
- package/dist/services/InstallationService.js.map +1 -0
- package/dist/services/MCPManager.js +1 -197
- package/dist/services/MCPManager.js.map +1 -0
- package/dist/services/RequirementService.js +1 -548
- package/dist/services/RequirementService.js.map +1 -0
- package/dist/services/ServerService.js +1 -127
- package/dist/services/ServerService.js.map +1 -0
- package/dist/services/TelemetryService.js +1 -53
- package/dist/services/TelemetryService.js.map +1 -0
- package/dist/utils/UpdateCheckTracker.js +1 -79
- package/dist/utils/UpdateCheckTracker.js.map +1 -0
- package/dist/utils/adoUtils.js +1 -254
- package/dist/utils/adoUtils.js.map +1 -0
- package/dist/utils/clientUtils.js +1 -65
- package/dist/utils/clientUtils.js.map +1 -0
- package/dist/utils/feedUtils.js +1 -28
- package/dist/utils/feedUtils.js.map +1 -0
- package/dist/utils/githubAuth.js +1 -177
- package/dist/utils/githubAuth.js.map +1 -0
- package/dist/utils/githubUtils.js +1 -125
- package/dist/utils/githubUtils.js.map +1 -0
- package/dist/utils/logger.js +1 -176
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/macroExpressionUtils.js +1 -93
- package/dist/utils/macroExpressionUtils.js.map +1 -0
- package/dist/utils/osUtils.js +1 -664
- package/dist/utils/osUtils.js.map +1 -0
- package/dist/utils/versionUtils.js +1 -101
- package/dist/utils/versionUtils.js.map +1 -0
- package/dist/web/contract/serverContract.js +1 -1
- package/dist/web/contract/serverContract.js.map +1 -0
- package/dist/web/public/js/api.js +2 -132
- package/dist/web/public/js/api.js.map +1 -0
- package/dist/web/public/js/detailsWidget.js +2 -264
- package/dist/web/public/js/detailsWidget.js.map +1 -0
- package/dist/web/public/js/flights/flights.js +2 -127
- package/dist/web/public/js/flights/flights.js.map +1 -0
- package/dist/web/public/js/modal/index.js +2 -52
- package/dist/web/public/js/modal/index.js.map +1 -0
- package/dist/web/public/js/modal/installModal.js +2 -162
- package/dist/web/public/js/modal/installModal.js.map +1 -0
- package/dist/web/public/js/modal/installation.js +2 -266
- package/dist/web/public/js/modal/installation.js.map +1 -0
- package/dist/web/public/js/modal/loadingModal.js +2 -182
- package/dist/web/public/js/modal/loadingModal.js.map +1 -0
- package/dist/web/public/js/modal/modalSetup.js +2 -595
- package/dist/web/public/js/modal/modalSetup.js.map +1 -0
- package/dist/web/public/js/modal/modalUtils.js +2 -37
- package/dist/web/public/js/modal/modalUtils.js.map +1 -0
- package/dist/web/public/js/modal/versionUtils.js +2 -20
- package/dist/web/public/js/modal/versionUtils.js.map +1 -0
- package/dist/web/public/js/modal.js +2 -42
- package/dist/web/public/js/modal.js.map +1 -0
- package/dist/web/public/js/notifications.js +2 -137
- package/dist/web/public/js/notifications.js.map +1 -0
- package/dist/web/public/js/onboard/formProcessor.js +2 -1037
- package/dist/web/public/js/onboard/formProcessor.js.map +1 -0
- package/dist/web/public/js/onboard/index.js +2 -374
- package/dist/web/public/js/onboard/index.js.map +1 -0
- package/dist/web/public/js/onboard/publishHandler.js +2 -172
- package/dist/web/public/js/onboard/publishHandler.js.map +1 -0
- package/dist/web/public/js/onboard/state.js +2 -76
- package/dist/web/public/js/onboard/state.js.map +1 -0
- package/dist/web/public/js/onboard/templates.js +2 -342
- package/dist/web/public/js/onboard/templates.js.map +1 -0
- package/dist/web/public/js/onboard/uiHandlers.js +2 -1076
- package/dist/web/public/js/onboard/uiHandlers.js.map +1 -0
- package/dist/web/public/js/onboard/validationHandlers.js +2 -493
- package/dist/web/public/js/onboard/validationHandlers.js.map +1 -0
- package/dist/web/public/js/serverCategoryDetails.js +2 -364
- package/dist/web/public/js/serverCategoryDetails.js.map +1 -0
- package/dist/web/public/js/serverCategoryList.js +2 -241
- package/dist/web/public/js/serverCategoryList.js.map +1 -0
- package/dist/web/public/js/settings.js +2 -314
- package/dist/web/public/js/settings.js.map +1 -0
- package/dist/web/server.js +1 -404
- package/dist/web/server.js.map +1 -0
- package/package.json +8 -2
- package/.github/ISSUE_TEMPLATE/JitAccess.yml +0 -28
- package/.github/acl/access.yml +0 -20
- package/.github/compliance/inventory.yml +0 -5
- package/.github/policies/jit.yml +0 -19
- package/.github/workflows/build.yml +0 -28
- package/.roo/rules-code/rules.md +0 -88
- package/dist/cli/commands/start.d.ts +0 -2
- package/dist/cli/commands/start.js +0 -32
- package/dist/cli/commands/sync.d.ts +0 -2
- package/dist/cli/commands/sync.js +0 -17
- package/dist/core/ConfigurationLoader.d.ts +0 -32
- package/dist/core/ConfigurationLoader.js +0 -236
- package/dist/core/ConfigurationProvider.d.ts +0 -35
- package/dist/core/ConfigurationProvider.js +0 -375
- package/dist/core/InstallationService.d.ts +0 -50
- package/dist/core/InstallationService.js +0 -350
- package/dist/core/MCPManager.d.ts +0 -28
- package/dist/core/MCPManager.js +0 -188
- package/dist/core/RequirementService.d.ts +0 -40
- package/dist/core/RequirementService.js +0 -110
- package/dist/core/ServerSchemaLoader.d.ts +0 -11
- package/dist/core/ServerSchemaLoader.js +0 -43
- package/dist/core/ServerSchemaProvider.d.ts +0 -17
- package/dist/core/ServerSchemaProvider.js +0 -120
- package/dist/core/constants.d.ts +0 -47
- package/dist/core/constants.js +0 -94
- package/dist/core/installers/BaseInstaller.d.ts +0 -74
- package/dist/core/installers/BaseInstaller.js +0 -253
- package/dist/core/installers/ClientInstaller.d.ts +0 -23
- package/dist/core/installers/ClientInstaller.js +0 -564
- package/dist/core/installers/CommandInstaller.d.ts +0 -37
- package/dist/core/installers/CommandInstaller.js +0 -173
- package/dist/core/installers/GeneralInstaller.d.ts +0 -33
- package/dist/core/installers/GeneralInstaller.js +0 -85
- package/dist/core/installers/InstallerFactory.d.ts +0 -54
- package/dist/core/installers/InstallerFactory.js +0 -97
- package/dist/core/installers/NpmInstaller.d.ts +0 -26
- package/dist/core/installers/NpmInstaller.js +0 -127
- package/dist/core/installers/PipInstaller.d.ts +0 -28
- package/dist/core/installers/PipInstaller.js +0 -127
- package/dist/core/installers/RequirementInstaller.d.ts +0 -33
- package/dist/core/installers/RequirementInstaller.js +0 -3
- package/dist/core/types.d.ts +0 -166
- package/dist/core/types.js +0 -16
- package/dist/services/InstallRequestValidator.d.ts +0 -21
- package/dist/services/InstallRequestValidator.js +0 -99
- package/dist/web/public/js/modal/installHandler.js +0 -227
- package/dist/web/public/js/modal/loadingUI.js +0 -74
- package/dist/web/public/js/modal/messageQueue.js +0 -112
- package/dist/web/public/js/modal/modalUI.js +0 -214
- package/dist/web/public/js/modal/version.js +0 -20
- package/dist/web/public/js/onboard/ONBOARDING_PAGE_DESIGN.md +0 -370
- package/docs/ONBOARDING_PAGE_DESIGN.md +0 -260
- package/docs/Telemetry.md +0 -136
- package/memory-bank/activeContext.md +0 -26
- package/memory-bank/decisionLog.md +0 -91
- package/memory-bank/productContext.md +0 -41
- package/memory-bank/progress.md +0 -35
- package/memory-bank/systemPatterns.md +0 -10
- package/src/cli/commands/install.ts +0 -139
- package/src/cli/commands/list.ts +0 -113
- package/src/cli/commands/pull.ts +0 -16
- package/src/cli/commands/serve.ts +0 -39
- package/src/cli/commands/uninstall.ts +0 -64
- package/src/cli/index.ts +0 -82
- package/src/core/installers/clients/BaseClientInstaller.ts +0 -341
- package/src/core/installers/clients/ClientInstaller.ts +0 -222
- package/src/core/installers/clients/ClientInstallerFactory.ts +0 -43
- package/src/core/installers/clients/ClineInstaller.ts +0 -35
- package/src/core/installers/clients/ExtensionInstaller.ts +0 -165
- package/src/core/installers/clients/GithubCopilotInstaller.ts +0 -79
- package/src/core/installers/clients/MSRooCodeInstaller.ts +0 -32
- package/src/core/installers/index.ts +0 -11
- package/src/core/installers/requirements/BaseInstaller.ts +0 -85
- package/src/core/installers/requirements/CommandInstaller.ts +0 -231
- package/src/core/installers/requirements/GeneralInstaller.ts +0 -133
- package/src/core/installers/requirements/InstallerFactory.ts +0 -114
- package/src/core/installers/requirements/NpmInstaller.ts +0 -271
- package/src/core/installers/requirements/NugetInstaller.ts +0 -203
- package/src/core/installers/requirements/PipInstaller.ts +0 -207
- package/src/core/installers/requirements/RequirementInstaller.ts +0 -42
- package/src/core/loaders/ConfigurationLoader.ts +0 -298
- package/src/core/loaders/ConfigurationProvider.ts +0 -462
- package/src/core/loaders/InstallOperationManager.ts +0 -367
- package/src/core/loaders/ServerSchemaLoader.ts +0 -117
- package/src/core/loaders/ServerSchemaProvider.ts +0 -99
- package/src/core/loaders/SystemSettingsManager.ts +0 -278
- package/src/core/metadatas/constants.ts +0 -122
- package/src/core/metadatas/recordingConstants.ts +0 -65
- package/src/core/metadatas/types.ts +0 -202
- package/src/core/onboard/FeedOnboardService.ts +0 -501
- package/src/core/onboard/OnboardProcessor.ts +0 -356
- package/src/core/onboard/OnboardStatus.ts +0 -60
- package/src/core/onboard/OnboardStatusManager.ts +0 -416
- package/src/core/validators/FeedValidator.ts +0 -135
- package/src/core/validators/IServerValidator.ts +0 -21
- package/src/core/validators/SSEServerValidator.ts +0 -43
- package/src/core/validators/ServerValidatorFactory.ts +0 -51
- package/src/core/validators/StdioServerValidator.ts +0 -313
- package/src/index.ts +0 -44
- package/src/services/InstallationService.ts +0 -102
- package/src/services/MCPManager.ts +0 -249
- package/src/services/RequirementService.ts +0 -627
- package/src/services/ServerService.ts +0 -161
- package/src/services/TelemetryService.ts +0 -59
- package/src/utils/UpdateCheckTracker.ts +0 -86
- package/src/utils/adoUtils.ts +0 -293
- package/src/utils/clientUtils.ts +0 -72
- package/src/utils/feedUtils.ts +0 -31
- package/src/utils/githubAuth.ts +0 -212
- package/src/utils/githubUtils.ts +0 -164
- package/src/utils/logger.ts +0 -195
- package/src/utils/macroExpressionUtils.ts +0 -104
- package/src/utils/osUtils.ts +0 -700
- package/src/utils/versionUtils.ts +0 -114
- package/src/web/contract/serverContract.ts +0 -74
- package/src/web/public/css/detailsWidget.css +0 -235
- package/src/web/public/css/modal.css +0 -757
- package/src/web/public/css/notifications.css +0 -101
- package/src/web/public/css/onboard.css +0 -107
- package/src/web/public/css/serverCategoryList.css +0 -120
- package/src/web/public/css/serverDetails.css +0 -139
- package/src/web/public/index.html +0 -359
- package/src/web/public/js/api.js +0 -132
- package/src/web/public/js/detailsWidget.js +0 -264
- package/src/web/public/js/flights/flights.js +0 -127
- package/src/web/public/js/modal/index.js +0 -52
- package/src/web/public/js/modal/installModal.js +0 -162
- package/src/web/public/js/modal/installation.js +0 -266
- package/src/web/public/js/modal/loadingModal.js +0 -182
- package/src/web/public/js/modal/modalSetup.js +0 -595
- package/src/web/public/js/modal/modalUtils.js +0 -37
- package/src/web/public/js/modal/versionUtils.js +0 -20
- package/src/web/public/js/modal.js +0 -42
- package/src/web/public/js/notifications.js +0 -137
- package/src/web/public/js/onboard/formProcessor.js +0 -1037
- package/src/web/public/js/onboard/index.js +0 -374
- package/src/web/public/js/onboard/publishHandler.js +0 -172
- package/src/web/public/js/onboard/state.js +0 -76
- package/src/web/public/js/onboard/templates.js +0 -342
- package/src/web/public/js/onboard/uiHandlers.js +0 -1076
- package/src/web/public/js/onboard/validationHandlers.js +0 -493
- package/src/web/public/js/serverCategoryDetails.js +0 -364
- package/src/web/public/js/serverCategoryList.js +0 -241
- package/src/web/public/js/settings.js +0 -314
- package/src/web/public/modal.html +0 -84
- package/src/web/public/onboard.html +0 -296
- package/src/web/public/settings.html +0 -135
- package/src/web/public/styles.css +0 -277
- package/src/web/server.ts +0 -478
- package/tsconfig.json +0 -18
- package/wiki/Installation.md +0 -3
- package/wiki/Publish.md +0 -3
|
@@ -1,384 +1,2 @@
|
|
|
1
|
-
import fs from
|
|
2
|
-
import path from 'path';
|
|
3
|
-
import { exec } from 'child_process';
|
|
4
|
-
import { promisify } from 'util';
|
|
5
|
-
import { fileURLToPath } from 'url';
|
|
6
|
-
import { GITHUB_REPO, LOCAL_FEEDS_DIR, SETTINGS_DIR, SUPPORTED_CLIENTS } from '../metadatas/constants.js';
|
|
7
|
-
import { Logger } from '../../utils/logger.js';
|
|
8
|
-
import { checkGithubAuth } from '../../utils/githubAuth.js';
|
|
9
|
-
import { ConfigurationLoader } from './ConfigurationLoader.js';
|
|
10
|
-
const execAsync = promisify(exec);
|
|
11
|
-
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
12
|
-
export class ConfigurationProvider {
|
|
13
|
-
static instance;
|
|
14
|
-
configPath;
|
|
15
|
-
configuration;
|
|
16
|
-
configLock = Promise.resolve();
|
|
17
|
-
tempDir;
|
|
18
|
-
constructor() {
|
|
19
|
-
// Initialize configuration in user's appdata/imcp directory
|
|
20
|
-
this.configPath = path.join(SETTINGS_DIR, 'configurations.json');
|
|
21
|
-
this.configuration = {
|
|
22
|
-
localServerCategories: [],
|
|
23
|
-
feeds: {},
|
|
24
|
-
clientMCPSettings: {}
|
|
25
|
-
};
|
|
26
|
-
this.tempDir = path.join(LOCAL_FEEDS_DIR, '../temp');
|
|
27
|
-
}
|
|
28
|
-
static getInstance() {
|
|
29
|
-
if (!ConfigurationProvider.instance) {
|
|
30
|
-
ConfigurationProvider.instance = new ConfigurationProvider();
|
|
31
|
-
}
|
|
32
|
-
return ConfigurationProvider.instance;
|
|
33
|
-
}
|
|
34
|
-
async withLock(operation) {
|
|
35
|
-
const current = this.configLock;
|
|
36
|
-
let resolve;
|
|
37
|
-
this.configLock = new Promise(r => resolve = r);
|
|
38
|
-
try {
|
|
39
|
-
await current;
|
|
40
|
-
return await operation();
|
|
41
|
-
}
|
|
42
|
-
finally {
|
|
43
|
-
resolve();
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
async initialize(feedFile, settings) {
|
|
47
|
-
await this.withLock(async () => {
|
|
48
|
-
const configDir = path.dirname(this.configPath);
|
|
49
|
-
await fs.mkdir(configDir, { recursive: true });
|
|
50
|
-
// remove the old configuration file if it exists
|
|
51
|
-
try {
|
|
52
|
-
await fs.rm(this.configPath, { recursive: true, force: true });
|
|
53
|
-
}
|
|
54
|
-
catch (error) {
|
|
55
|
-
if (error.code !== 'ENOENT') {
|
|
56
|
-
throw error;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
try {
|
|
60
|
-
try {
|
|
61
|
-
const config = JSON.parse(await fs.readFile(this.configPath, 'utf8'));
|
|
62
|
-
this.configuration = config;
|
|
63
|
-
}
|
|
64
|
-
catch (error) {
|
|
65
|
-
if (error.code !== 'ENOENT') {
|
|
66
|
-
throw error;
|
|
67
|
-
}
|
|
68
|
-
// File doesn't exist, use default empty configuration
|
|
69
|
-
await this.saveConfiguration();
|
|
70
|
-
}
|
|
71
|
-
// Always load feeds and client settings, whether file existed or not
|
|
72
|
-
await this.loadFeedsIntoConfiguration(feedFile, settings);
|
|
73
|
-
await this.loadClientMCPSettings();
|
|
74
|
-
}
|
|
75
|
-
catch (error) {
|
|
76
|
-
Logger.error('Error during initialization', error);
|
|
77
|
-
throw error;
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
async saveConfiguration() {
|
|
82
|
-
const configDir = path.dirname(this.configPath);
|
|
83
|
-
await fs.mkdir(configDir, { recursive: true });
|
|
84
|
-
await fs.writeFile(this.configPath, JSON.stringify(this.configuration, null, 2));
|
|
85
|
-
}
|
|
86
|
-
async getServerCategories() {
|
|
87
|
-
return await this.withLock(async () => {
|
|
88
|
-
return this.configuration.localServerCategories;
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
async getServerCategory(categoryName) {
|
|
92
|
-
return await this.withLock(async () => {
|
|
93
|
-
return this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
async getClientMcpSettings() {
|
|
97
|
-
return await this.withLock(async () => {
|
|
98
|
-
return this.configuration.clientMCPSettings;
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
async getFeedConfiguration(categoryName) {
|
|
102
|
-
return await this.withLock(async () => {
|
|
103
|
-
return this.configuration.feeds[categoryName];
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
async getServerMcpConfig(categoryName, serverName) {
|
|
107
|
-
return await this.withLock(async () => {
|
|
108
|
-
return this.configuration.feeds[categoryName]?.mcpServers.find(s => s.name === serverName);
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
async getInstallationStatus(categoryName) {
|
|
112
|
-
return await this.withLock(async () => {
|
|
113
|
-
// Inline getServerCategory logic
|
|
114
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
115
|
-
return category?.installationStatus;
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
async getServerStatus(categoryName, serverName) {
|
|
119
|
-
return await this.withLock(async () => {
|
|
120
|
-
// Inline getInstallationStatus logic
|
|
121
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
122
|
-
const status = category?.installationStatus;
|
|
123
|
-
return status?.serversStatus[serverName];
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
async getRequirementStatus(categoryName, requirementName) {
|
|
127
|
-
return await this.withLock(async () => {
|
|
128
|
-
// Inline getInstallationStatus logic
|
|
129
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
130
|
-
const status = category?.installationStatus;
|
|
131
|
-
return status?.requirementsStatus[requirementName];
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
async updateInstallationStatus(categoryName, requirementStatus, serverStatus) {
|
|
135
|
-
return await this.withLock(async () => {
|
|
136
|
-
// Inline getServerCategory logic
|
|
137
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
138
|
-
if (!category)
|
|
139
|
-
return false;
|
|
140
|
-
if (!category.installationStatus) {
|
|
141
|
-
category.installationStatus = {
|
|
142
|
-
requirementsStatus: {},
|
|
143
|
-
serversStatus: {},
|
|
144
|
-
lastUpdated: new Date().toISOString()
|
|
145
|
-
};
|
|
146
|
-
}
|
|
147
|
-
category.installationStatus.requirementsStatus = {
|
|
148
|
-
...category.installationStatus.requirementsStatus,
|
|
149
|
-
...requirementStatus
|
|
150
|
-
};
|
|
151
|
-
category.installationStatus.serversStatus = {
|
|
152
|
-
...category.installationStatus.serversStatus,
|
|
153
|
-
...serverStatus
|
|
154
|
-
};
|
|
155
|
-
category.installationStatus.lastUpdated = new Date().toISOString();
|
|
156
|
-
await this.saveConfiguration();
|
|
157
|
-
return true;
|
|
158
|
-
});
|
|
159
|
-
}
|
|
160
|
-
async updateRequirementStatus(categoryName, requirementName, status) {
|
|
161
|
-
return await this.withLock(async () => {
|
|
162
|
-
// Inline getServerCategory logic
|
|
163
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
164
|
-
if (!category?.installationStatus)
|
|
165
|
-
return false;
|
|
166
|
-
category.installationStatus.requirementsStatus[requirementName] = status;
|
|
167
|
-
category.installationStatus.lastUpdated = new Date().toISOString();
|
|
168
|
-
await this.saveConfiguration();
|
|
169
|
-
return true;
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
async updateRequirementOperationStatus(categoryName, requirementName, operationStatus) {
|
|
173
|
-
return await this.withLock(async () => {
|
|
174
|
-
// Inline getServerCategory logic
|
|
175
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
176
|
-
if (!category?.installationStatus?.requirementsStatus[requirementName])
|
|
177
|
-
return false;
|
|
178
|
-
category.installationStatus.requirementsStatus[requirementName].operationStatus = operationStatus;
|
|
179
|
-
category.installationStatus.lastUpdated = new Date().toISOString();
|
|
180
|
-
await this.saveConfiguration();
|
|
181
|
-
return true;
|
|
182
|
-
});
|
|
183
|
-
}
|
|
184
|
-
async updateServerStatus(categoryName, serverName, status) {
|
|
185
|
-
return await this.withLock(async () => {
|
|
186
|
-
// Inline getServerCategory logic
|
|
187
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
188
|
-
if (!category?.installationStatus)
|
|
189
|
-
return false;
|
|
190
|
-
category.installationStatus.serversStatus[serverName] = status;
|
|
191
|
-
category.installationStatus.lastUpdated = new Date().toISOString();
|
|
192
|
-
await this.saveConfiguration();
|
|
193
|
-
return true;
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
async updateServerOperationStatus(categoryName, serverName, clientName, operationStatus) {
|
|
197
|
-
return await this.withLock(async () => {
|
|
198
|
-
// Inline getServerCategory logic
|
|
199
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
200
|
-
if (!category?.installationStatus?.serversStatus[serverName])
|
|
201
|
-
return false;
|
|
202
|
-
category.installationStatus.serversStatus[serverName].installedStatus[clientName] = operationStatus;
|
|
203
|
-
category.installationStatus.lastUpdated = new Date().toISOString();
|
|
204
|
-
await this.saveConfiguration();
|
|
205
|
-
return true;
|
|
206
|
-
});
|
|
207
|
-
}
|
|
208
|
-
async isRequirementsReady(categoryName, serverName) {
|
|
209
|
-
return await this.withLock(async () => {
|
|
210
|
-
// Inline getServerCategory logic
|
|
211
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
212
|
-
if (!category?.feedConfiguration)
|
|
213
|
-
return false;
|
|
214
|
-
const serverConfig = category.feedConfiguration.mcpServers.find(s => s.name === serverName);
|
|
215
|
-
if (!serverConfig?.dependencies?.requirements)
|
|
216
|
-
return true; // No requirements means ready
|
|
217
|
-
const requirementNames = serverConfig.dependencies.requirements.map(r => r.name);
|
|
218
|
-
// Inline getInstallationStatus logic (using the already fetched category)
|
|
219
|
-
const status = category?.installationStatus;
|
|
220
|
-
if (!status?.requirementsStatus)
|
|
221
|
-
return false;
|
|
222
|
-
return requirementNames.every(name => {
|
|
223
|
-
const reqStatus = status.requirementsStatus[name];
|
|
224
|
-
return reqStatus?.installed && !reqStatus?.error;
|
|
225
|
-
});
|
|
226
|
-
});
|
|
227
|
-
}
|
|
228
|
-
async GetServerRequirementStatus(categoryName, serverName) {
|
|
229
|
-
return await this.withLock(async () => {
|
|
230
|
-
// Inline getServerCategory logic
|
|
231
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
232
|
-
if (!category?.feedConfiguration)
|
|
233
|
-
return [];
|
|
234
|
-
const serverConfig = category.feedConfiguration.mcpServers.find(s => s.name === serverName);
|
|
235
|
-
if (!serverConfig?.dependencies?.requirements)
|
|
236
|
-
return [];
|
|
237
|
-
const requirementNames = serverConfig.dependencies.requirements.map(r => r.name);
|
|
238
|
-
return requirementNames
|
|
239
|
-
.map(name => category?.installationStatus?.requirementsStatus[name])
|
|
240
|
-
.filter(x => x !== undefined);
|
|
241
|
-
});
|
|
242
|
-
}
|
|
243
|
-
async isServerReady(categoryName, serverName, clients) {
|
|
244
|
-
return await this.withLock(async () => {
|
|
245
|
-
// Inline the logic from getServerStatus and getInstallationStatus to avoid nested lock
|
|
246
|
-
const category = this.configuration.localServerCategories.find(s => s.name === categoryName);
|
|
247
|
-
const installationStatus = category?.installationStatus;
|
|
248
|
-
const serverStatus = installationStatus?.serversStatus[serverName];
|
|
249
|
-
if (!serverStatus)
|
|
250
|
-
return false;
|
|
251
|
-
return clients.every(clientName => {
|
|
252
|
-
// Add optional chaining for safety in case installedStatus is missing
|
|
253
|
-
const clientStatus = serverStatus.installedStatus?.[clientName];
|
|
254
|
-
return clientStatus?.status === 'completed' && !clientStatus?.error;
|
|
255
|
-
});
|
|
256
|
-
});
|
|
257
|
-
}
|
|
258
|
-
async syncFeeds() {
|
|
259
|
-
return await this.withLock(async () => {
|
|
260
|
-
Logger.log('Starting feed synchronization...');
|
|
261
|
-
try {
|
|
262
|
-
// Check GitHub authentication first
|
|
263
|
-
await checkGithubAuth();
|
|
264
|
-
Logger.debug({
|
|
265
|
-
action: 'create_directories',
|
|
266
|
-
paths: {
|
|
267
|
-
localFeeds: LOCAL_FEEDS_DIR,
|
|
268
|
-
tempDir: this.tempDir
|
|
269
|
-
}
|
|
270
|
-
});
|
|
271
|
-
await fs.mkdir(LOCAL_FEEDS_DIR, { recursive: true });
|
|
272
|
-
await fs.mkdir(this.tempDir, { recursive: true });
|
|
273
|
-
// Clean up temp directory
|
|
274
|
-
await fs.rm(this.tempDir, { recursive: true, force: true });
|
|
275
|
-
// Download latest release
|
|
276
|
-
Logger.debug('Downloading latest release...');
|
|
277
|
-
const { downloadGithubRelease } = await import('../../utils/githubUtils.js');
|
|
278
|
-
const { version, downloadPath } = await downloadGithubRelease(GITHUB_REPO.repoName, 'latest', GITHUB_REPO.feedAssetsName, undefined, true, this.tempDir);
|
|
279
|
-
Logger.debug({
|
|
280
|
-
action: 'download_release',
|
|
281
|
-
downloadPath,
|
|
282
|
-
version,
|
|
283
|
-
repoName: GITHUB_REPO.repoName,
|
|
284
|
-
});
|
|
285
|
-
Logger.debug('Updating local feeds...');
|
|
286
|
-
await fs.rm(LOCAL_FEEDS_DIR, { recursive: true, force: true });
|
|
287
|
-
const sourceFeedsDir = downloadPath;
|
|
288
|
-
try {
|
|
289
|
-
await fs.access(downloadPath);
|
|
290
|
-
}
|
|
291
|
-
catch (err) {
|
|
292
|
-
throw new Error(`Could not find feeds directory in downloaded path: ${sourceFeedsDir}`);
|
|
293
|
-
}
|
|
294
|
-
await fs.cp(sourceFeedsDir, LOCAL_FEEDS_DIR, { recursive: true, force: true });
|
|
295
|
-
Logger.log('Successfully updated local feeds');
|
|
296
|
-
}
|
|
297
|
-
catch (error) {
|
|
298
|
-
Logger.error('Error during feed synchronization', error);
|
|
299
|
-
throw new Error('Failed to sync feeds. Use --verbose for detailed error information.');
|
|
300
|
-
}
|
|
301
|
-
});
|
|
302
|
-
}
|
|
303
|
-
async loadFeedsIntoConfiguration(feedFile, settings) {
|
|
304
|
-
this.configuration = await ConfigurationLoader.loadFeedsIntoConfiguration(this.configuration, feedFile, settings);
|
|
305
|
-
await this.saveConfiguration();
|
|
306
|
-
}
|
|
307
|
-
async loadClientMCPSettings() {
|
|
308
|
-
this.configuration = await ConfigurationLoader.loadClientMCPSettings(this.configuration);
|
|
309
|
-
await this.saveConfiguration();
|
|
310
|
-
}
|
|
311
|
-
// Public method to reload client MCP settings
|
|
312
|
-
async reloadClientMCPSettings() {
|
|
313
|
-
return await this.withLock(async () => {
|
|
314
|
-
await this.loadClientMCPSettings();
|
|
315
|
-
});
|
|
316
|
-
}
|
|
317
|
-
async removeServerFromClientMCPSettings(serverName, target) {
|
|
318
|
-
return await this.withLock(async () => {
|
|
319
|
-
// Load utils in async context to avoid circular dependencies
|
|
320
|
-
const { readJsonFile, writeJsonFile } = await import('../../utils/clientUtils.js');
|
|
321
|
-
// Filter clients if target is specified
|
|
322
|
-
const clientEntries = Object.entries(SUPPORTED_CLIENTS);
|
|
323
|
-
const targetClients = target
|
|
324
|
-
? clientEntries.filter(([clientName]) => clientName === target)
|
|
325
|
-
: clientEntries;
|
|
326
|
-
for (const [clientName, clientSettings] of targetClients) {
|
|
327
|
-
const settingPath = process.env.CODE_INSIDERS
|
|
328
|
-
? clientSettings.codeInsiderSettingPath
|
|
329
|
-
: clientSettings.codeSettingPath;
|
|
330
|
-
try {
|
|
331
|
-
const content = await readJsonFile(settingPath, true);
|
|
332
|
-
let modified = false;
|
|
333
|
-
// Handle GitHub Copilot's different structure
|
|
334
|
-
if (clientName === 'GithubCopilot' && content.mcp?.servers?.[serverName]) {
|
|
335
|
-
delete content.mcp.servers[serverName];
|
|
336
|
-
modified = true;
|
|
337
|
-
}
|
|
338
|
-
else if (content.mcpServers?.[serverName]) {
|
|
339
|
-
delete content.mcpServers[serverName];
|
|
340
|
-
modified = true;
|
|
341
|
-
}
|
|
342
|
-
// Only write if we actually modified the content
|
|
343
|
-
if (modified) {
|
|
344
|
-
await writeJsonFile(settingPath, content);
|
|
345
|
-
Logger.debug(`Removed server ${serverName} from client ${clientName} settings`);
|
|
346
|
-
}
|
|
347
|
-
}
|
|
348
|
-
catch (error) {
|
|
349
|
-
Logger.error(`Failed to remove server ${serverName} from client ${clientName} settings:`, error);
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
// Also update our in-memory configuration
|
|
353
|
-
if (this.configuration.clientMCPSettings) {
|
|
354
|
-
if (target) {
|
|
355
|
-
// Only update settings for the target client
|
|
356
|
-
const clientSettings = this.configuration.clientMCPSettings[target];
|
|
357
|
-
if (clientSettings) {
|
|
358
|
-
if (clientSettings.mcpServers?.[serverName]) {
|
|
359
|
-
delete clientSettings.mcpServers[serverName];
|
|
360
|
-
}
|
|
361
|
-
if (clientSettings.servers?.[serverName]) { // For GitHub Copilot
|
|
362
|
-
delete clientSettings.servers[serverName];
|
|
363
|
-
}
|
|
364
|
-
}
|
|
365
|
-
}
|
|
366
|
-
else {
|
|
367
|
-
// Update all clients if no target specified
|
|
368
|
-
for (const clientSettings of Object.values(this.configuration.clientMCPSettings)) {
|
|
369
|
-
if (clientSettings.mcpServers?.[serverName]) {
|
|
370
|
-
delete clientSettings.mcpServers[serverName];
|
|
371
|
-
}
|
|
372
|
-
if (clientSettings.servers?.[serverName]) { // For GitHub Copilot
|
|
373
|
-
delete clientSettings.servers[serverName];
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
await this.saveConfiguration();
|
|
378
|
-
}
|
|
379
|
-
});
|
|
380
|
-
}
|
|
381
|
-
}
|
|
382
|
-
// Export a singleton instance
|
|
383
|
-
export const configProvider = ConfigurationProvider.getInstance();
|
|
1
|
+
import fs from"fs/promises";import path from"path";import{exec}from"child_process";import{promisify}from"util";import{fileURLToPath}from"url";import{GITHUB_REPO,LOCAL_FEEDS_DIR,SETTINGS_DIR,SUPPORTED_CLIENTS}from"../metadatas/constants.js";import{Logger}from"../../utils/logger.js";import{checkGithubAuth}from"../../utils/githubAuth.js";import{ConfigurationLoader}from"./ConfigurationLoader.js";const execAsync=promisify(exec),__dirname=path.dirname(fileURLToPath(import.meta.url));export class ConfigurationProvider{static instance;configPath;configuration;configLock=Promise.resolve();tempDir;constructor(){this.configPath=path.join(SETTINGS_DIR,"configurations.json"),this.configuration={localServerCategories:[],feeds:{},clientMCPSettings:{}},this.tempDir=path.join(LOCAL_FEEDS_DIR,"../temp")}static getInstance(){return ConfigurationProvider.instance||(ConfigurationProvider.instance=new ConfigurationProvider),ConfigurationProvider.instance}async withLock(t){const e=this.configLock;let i;this.configLock=new Promise((t=>i=t));try{return await e,await t()}finally{i()}}async initialize(t,e){await this.withLock((async()=>{const i=path.dirname(this.configPath);await fs.mkdir(i,{recursive:!0});try{await fs.rm(this.configPath,{recursive:!0,force:!0})}catch(t){if("ENOENT"!==t.code)throw t}try{try{const t=JSON.parse(await fs.readFile(this.configPath,"utf8"));this.configuration=t}catch(t){if("ENOENT"!==t.code)throw t;await this.saveConfiguration()}await this.loadFeedsIntoConfiguration(t,e),await this.loadClientMCPSettings()}catch(t){throw Logger.error("Error during initialization",t),t}}))}async saveConfiguration(){const t=path.dirname(this.configPath);await fs.mkdir(t,{recursive:!0}),await fs.writeFile(this.configPath,JSON.stringify(this.configuration,null,2))}async getServerCategories(){return await this.withLock((async()=>this.configuration.localServerCategories))}async getServerCategory(t){return await this.withLock((async()=>this.configuration.localServerCategories.find((e=>e.name===t))))}async getClientMcpSettings(){return await this.withLock((async()=>this.configuration.clientMCPSettings))}async getFeedConfiguration(t){return await this.withLock((async()=>this.configuration.feeds[t]))}async getServerMcpConfig(t,e){return await this.withLock((async()=>this.configuration.feeds[t]?.mcpServers.find((t=>t.name===e))))}async getInstallationStatus(t){return await this.withLock((async()=>{const e=this.configuration.localServerCategories.find((e=>e.name===t));return e?.installationStatus}))}async getServerStatus(t,e){return await this.withLock((async()=>{const i=this.configuration.localServerCategories.find((e=>e.name===t)),a=i?.installationStatus;return a?.serversStatus[e]}))}async getRequirementStatus(t,e){return await this.withLock((async()=>{const i=this.configuration.localServerCategories.find((e=>e.name===t)),a=i?.installationStatus;return a?.requirementsStatus[e]}))}async updateInstallationStatus(t,e,i){return await this.withLock((async()=>{const a=this.configuration.localServerCategories.find((e=>e.name===t));return!!a&&(a.installationStatus||(a.installationStatus={requirementsStatus:{},serversStatus:{},lastUpdated:(new Date).toISOString()}),a.installationStatus.requirementsStatus={...a.installationStatus.requirementsStatus,...e},a.installationStatus.serversStatus={...a.installationStatus.serversStatus,...i},a.installationStatus.lastUpdated=(new Date).toISOString(),await this.saveConfiguration(),!0)}))}async updateRequirementStatus(t,e,i){return await this.withLock((async()=>{const a=this.configuration.localServerCategories.find((e=>e.name===t));return!!a?.installationStatus&&(a.installationStatus.requirementsStatus[e]=i,a.installationStatus.lastUpdated=(new Date).toISOString(),await this.saveConfiguration(),!0)}))}async updateRequirementOperationStatus(t,e,i){return await this.withLock((async()=>{const a=this.configuration.localServerCategories.find((e=>e.name===t));return!!a?.installationStatus?.requirementsStatus[e]&&(a.installationStatus.requirementsStatus[e].operationStatus=i,a.installationStatus.lastUpdated=(new Date).toISOString(),await this.saveConfiguration(),!0)}))}async updateServerStatus(t,e,i){return await this.withLock((async()=>{const a=this.configuration.localServerCategories.find((e=>e.name===t));return!!a?.installationStatus&&(a.installationStatus.serversStatus[e]=i,a.installationStatus.lastUpdated=(new Date).toISOString(),await this.saveConfiguration(),!0)}))}async updateServerOperationStatus(t,e,i,a){return await this.withLock((async()=>{const r=this.configuration.localServerCategories.find((e=>e.name===t));return!!r?.installationStatus?.serversStatus[e]&&(r.installationStatus.serversStatus[e].installedStatus[i]=a,r.installationStatus.lastUpdated=(new Date).toISOString(),await this.saveConfiguration(),!0)}))}async isRequirementsReady(t,e){return await this.withLock((async()=>{const i=this.configuration.localServerCategories.find((e=>e.name===t));if(!i?.feedConfiguration)return!1;const a=i.feedConfiguration.mcpServers.find((t=>t.name===e));if(!a?.dependencies?.requirements)return!0;const r=a.dependencies.requirements.map((t=>t.name)),n=i?.installationStatus;return!!n?.requirementsStatus&&r.every((t=>{const e=n.requirementsStatus[t];return e?.installed&&!e?.error}))}))}async GetServerRequirementStatus(t,e){return await this.withLock((async()=>{const i=this.configuration.localServerCategories.find((e=>e.name===t));if(!i?.feedConfiguration)return[];const a=i.feedConfiguration.mcpServers.find((t=>t.name===e));return a?.dependencies?.requirements?a.dependencies.requirements.map((t=>t.name)).map((t=>i?.installationStatus?.requirementsStatus[t])).filter((t=>void 0!==t)):[]}))}async isServerReady(t,e,i){return await this.withLock((async()=>{const a=this.configuration.localServerCategories.find((e=>e.name===t)),r=a?.installationStatus,n=r?.serversStatus[e];return!!n&&i.every((t=>{const e=n.installedStatus?.[t];return"completed"===e?.status&&!e?.error}))}))}async syncFeeds(){return await this.withLock((async()=>{Logger.log("Starting feed synchronization...");try{await checkGithubAuth(),Logger.debug({action:"create_directories",paths:{localFeeds:LOCAL_FEEDS_DIR,tempDir:this.tempDir}}),await fs.mkdir(LOCAL_FEEDS_DIR,{recursive:!0}),await fs.mkdir(this.tempDir,{recursive:!0}),await fs.rm(this.tempDir,{recursive:!0,force:!0}),Logger.debug("Downloading latest release...");const{downloadGithubRelease:t}=await import("../../utils/githubUtils.js"),{version:e,downloadPath:i}=await t(GITHUB_REPO.repoName,"latest",GITHUB_REPO.feedAssetsName,void 0,!0,this.tempDir);Logger.debug({action:"download_release",downloadPath:i,version:e,repoName:GITHUB_REPO.repoName}),Logger.debug("Updating local feeds..."),await fs.rm(LOCAL_FEEDS_DIR,{recursive:!0,force:!0});const a=i;try{await fs.access(i)}catch(t){throw new Error(`Could not find feeds directory in downloaded path: ${a}`)}await fs.cp(a,LOCAL_FEEDS_DIR,{recursive:!0,force:!0}),Logger.log("Successfully updated local feeds")}catch(t){throw Logger.error("Error during feed synchronization",t),new Error("Failed to sync feeds. Use --verbose for detailed error information.")}}))}async loadFeedsIntoConfiguration(t,e){this.configuration=await ConfigurationLoader.loadFeedsIntoConfiguration(this.configuration,t,e),await this.saveConfiguration()}async loadClientMCPSettings(){this.configuration=await ConfigurationLoader.loadClientMCPSettings(this.configuration),await this.saveConfiguration()}async reloadClientMCPSettings(){return await this.withLock((async()=>{await this.loadClientMCPSettings()}))}async removeServerFromClientMCPSettings(t,e){return await this.withLock((async()=>{const{readJsonFile:i,writeJsonFile:a}=await import("../../utils/clientUtils.js"),r=Object.entries(SUPPORTED_CLIENTS),n=e?r.filter((([t])=>t===e)):r;for(const[e,r]of n){const n=process.env.CODE_INSIDERS?r.codeInsiderSettingPath:r.codeSettingPath;try{const r=await i(n,!0);let s=!1;"GithubCopilot"===e&&r.mcp?.servers?.[t]?(delete r.mcp.servers[t],s=!0):r.mcpServers?.[t]&&(delete r.mcpServers[t],s=!0),s&&(await a(n,r),Logger.debug(`Removed server ${t} from client ${e} settings`))}catch(i){Logger.error(`Failed to remove server ${t} from client ${e} settings:`,i)}}if(this.configuration.clientMCPSettings){if(e){const i=this.configuration.clientMCPSettings[e];i&&(i.mcpServers?.[t]&&delete i.mcpServers[t],i.servers?.[t]&&delete i.servers[t])}else for(const e of Object.values(this.configuration.clientMCPSettings))e.mcpServers?.[t]&&delete e.mcpServers[t],e.servers?.[t]&&delete e.servers[t];await this.saveConfiguration()}}))}}export const configProvider=ConfigurationProvider.getInstance();
|
|
384
2
|
//# sourceMappingURL=ConfigurationProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["fs","path","exec","promisify","fileURLToPath","GITHUB_REPO","LOCAL_FEEDS_DIR","SETTINGS_DIR","SUPPORTED_CLIENTS","Logger","checkGithubAuth","ConfigurationLoader","execAsync","__dirname","dirname","url","ConfigurationProvider","static","configPath","configuration","configLock","Promise","resolve","tempDir","constructor","this","join","localServerCategories","feeds","clientMCPSettings","getInstance","instance","withLock","operation","current","r","initialize","feedFile","settings","async","configDir","mkdir","recursive","rm","force","error","code","config","JSON","parse","readFile","saveConfiguration","loadFeedsIntoConfiguration","loadClientMCPSettings","writeFile","stringify","getServerCategories","getServerCategory","categoryName","find","s","name","getClientMcpSettings","getFeedConfiguration","getServerMcpConfig","serverName","mcpServers","getInstallationStatus","category","installationStatus","getServerStatus","status","serversStatus","getRequirementStatus","requirementName","requirementsStatus","updateInstallationStatus","requirementStatus","serverStatus","lastUpdated","Date","toISOString","updateRequirementStatus","updateRequirementOperationStatus","operationStatus","updateServerStatus","updateServerOperationStatus","clientName","installedStatus","isRequirementsReady","feedConfiguration","serverConfig","dependencies","requirements","requirementNames","map","every","reqStatus","installed","GetServerRequirementStatus","filter","x","undefined","isServerReady","clients","clientStatus","syncFeeds","log","debug","action","paths","localFeeds","downloadGithubRelease","import","version","downloadPath","repoName","feedAssetsName","sourceFeedsDir","access","err","Error","cp","reloadClientMCPSettings","removeServerFromClientMCPSettings","target","readJsonFile","writeJsonFile","clientEntries","Object","entries","targetClients","clientSettings","settingPath","process","env","CODE_INSIDERS","codeInsiderSettingPath","codeSettingPath","content","modified","mcp","servers","values","configProvider"],"sources":["../../../src/core/loaders/ConfigurationProvider.ts"],"mappings":"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","ignoreList":[]}
|