imcp 0.1.4 → 0.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +21 -4
- package/dist/cli/commands/install.js.map +1 -0
- package/dist/cli/commands/list.js.map +1 -0
- package/dist/cli/commands/pull.js.map +1 -0
- package/dist/cli/commands/serve.js.map +1 -0
- package/dist/cli/commands/start.d.ts +2 -0
- package/dist/cli/commands/start.js +32 -0
- package/dist/cli/commands/start.js.map +1 -0
- package/dist/cli/commands/sync.d.ts +2 -0
- package/dist/cli/commands/sync.js +17 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/commands/uninstall.js.map +1 -0
- package/dist/cli/index.js +0 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/core/ConfigurationLoader.d.ts +32 -0
- package/{src/core/loaders/ConfigurationLoader.ts → dist/core/ConfigurationLoader.js} +236 -298
- package/dist/core/ConfigurationLoader.js.map +1 -0
- package/dist/core/ConfigurationProvider.d.ts +35 -0
- package/{src/core/loaders/ConfigurationProvider.ts → dist/core/ConfigurationProvider.js} +375 -462
- package/dist/core/ConfigurationProvider.js.map +1 -0
- package/dist/core/InstallationService.d.ts +50 -0
- package/dist/core/InstallationService.js +350 -0
- package/dist/core/InstallationService.js.map +1 -0
- package/dist/core/MCPManager.d.ts +28 -0
- package/dist/core/MCPManager.js +188 -0
- package/dist/core/MCPManager.js.map +1 -0
- package/dist/core/RequirementService.d.ts +40 -0
- package/dist/core/RequirementService.js +110 -0
- package/dist/core/RequirementService.js.map +1 -0
- package/dist/core/ServerSchemaLoader.d.ts +11 -0
- package/dist/core/ServerSchemaLoader.js +43 -0
- package/dist/core/ServerSchemaLoader.js.map +1 -0
- package/dist/core/ServerSchemaProvider.d.ts +17 -0
- package/dist/core/ServerSchemaProvider.js +120 -0
- package/dist/core/ServerSchemaProvider.js.map +1 -0
- package/dist/core/constants.d.ts +47 -0
- package/dist/core/constants.js +94 -0
- package/dist/core/constants.js.map +1 -0
- package/dist/core/installers/BaseInstaller.d.ts +74 -0
- package/dist/core/installers/BaseInstaller.js +253 -0
- package/dist/core/installers/BaseInstaller.js.map +1 -0
- package/dist/core/installers/ClientInstaller.d.ts +23 -0
- package/dist/core/installers/ClientInstaller.js +564 -0
- package/dist/core/installers/ClientInstaller.js.map +1 -0
- package/dist/core/installers/CommandInstaller.d.ts +37 -0
- package/{src/core/installers/requirements/CommandInstaller.ts → dist/core/installers/CommandInstaller.js} +173 -231
- package/dist/core/installers/CommandInstaller.js.map +1 -0
- package/dist/core/installers/GeneralInstaller.d.ts +33 -0
- package/dist/core/installers/GeneralInstaller.js +85 -0
- package/dist/core/installers/GeneralInstaller.js.map +1 -0
- package/dist/core/installers/InstallerFactory.d.ts +54 -0
- package/{src/core/installers/requirements/InstallerFactory.ts → dist/core/installers/InstallerFactory.js} +97 -114
- package/dist/core/installers/InstallerFactory.js.map +1 -0
- package/dist/core/installers/NpmInstaller.d.ts +26 -0
- package/dist/core/installers/NpmInstaller.js +127 -0
- package/dist/core/installers/NpmInstaller.js.map +1 -0
- package/dist/core/installers/PipInstaller.d.ts +28 -0
- package/dist/core/installers/PipInstaller.js +127 -0
- package/dist/core/installers/PipInstaller.js.map +1 -0
- package/{src/core/installers/requirements/RequirementInstaller.ts → dist/core/installers/RequirementInstaller.d.ts} +33 -42
- package/dist/core/installers/RequirementInstaller.js +3 -0
- package/dist/core/installers/RequirementInstaller.js.map +1 -0
- package/dist/core/installers/clients/BaseClientInstaller.js.map +1 -0
- package/dist/core/installers/clients/ClientInstaller.js.map +1 -0
- package/dist/core/installers/clients/ClientInstallerFactory.js.map +1 -0
- package/dist/core/installers/clients/ClineInstaller.js.map +1 -0
- package/dist/core/installers/clients/ExtensionInstaller.js.map +1 -0
- package/dist/core/installers/clients/GithubCopilotInstaller.js.map +1 -0
- package/dist/core/installers/clients/MSRooCodeInstaller.js.map +1 -0
- package/dist/core/installers/index.js.map +1 -0
- package/dist/core/installers/requirements/BaseInstaller.js.map +1 -0
- package/dist/core/installers/requirements/CommandInstaller.js.map +1 -0
- package/dist/core/installers/requirements/GeneralInstaller.js.map +1 -0
- package/dist/core/installers/requirements/InstallerFactory.js.map +1 -0
- package/dist/core/installers/requirements/NpmInstaller.js.map +1 -0
- package/dist/core/installers/requirements/NugetInstaller.js.map +1 -0
- package/dist/core/installers/requirements/PipInstaller.js.map +1 -0
- package/dist/core/installers/requirements/RequirementInstaller.js.map +1 -0
- package/dist/core/loaders/ConfigurationLoader.js.map +1 -0
- package/dist/core/loaders/ConfigurationProvider.js.map +1 -0
- package/dist/core/loaders/InstallOperationManager.js.map +1 -0
- package/dist/core/loaders/ServerSchemaLoader.js.map +1 -0
- package/dist/core/loaders/ServerSchemaProvider.js.map +1 -0
- package/dist/core/loaders/SystemSettingsManager.js.map +1 -0
- package/dist/core/metadatas/constants.js.map +1 -0
- package/dist/core/metadatas/recordingConstants.js.map +1 -0
- package/dist/core/metadatas/types.js.map +1 -0
- package/dist/core/onboard/FeedOnboardService.js.map +1 -0
- package/dist/core/onboard/OnboardProcessor.js.map +1 -0
- package/dist/core/onboard/OnboardStatus.js.map +1 -0
- package/dist/core/onboard/OnboardStatusManager.js.map +1 -0
- package/dist/core/types.d.ts +166 -0
- package/dist/core/types.js +16 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/validators/FeedValidator.js.map +1 -0
- package/dist/core/validators/IServerValidator.js.map +1 -0
- package/dist/core/validators/SSEServerValidator.js.map +1 -0
- package/dist/core/validators/ServerValidatorFactory.js.map +1 -0
- package/dist/core/validators/StdioServerValidator.js.map +1 -0
- package/dist/index.js.map +1 -0
- package/dist/services/InstallRequestValidator.d.ts +21 -0
- package/dist/services/InstallRequestValidator.js +99 -0
- package/dist/services/InstallRequestValidator.js.map +1 -0
- package/dist/services/InstallationService.js.map +1 -0
- package/dist/services/MCPManager.js.map +1 -0
- package/dist/services/RequirementService.js.map +1 -0
- package/dist/services/ServerService.js.map +1 -0
- package/dist/services/TelemetryService.js.map +1 -0
- package/dist/utils/UpdateCheckTracker.js.map +1 -0
- package/dist/utils/adoUtils.js.map +1 -0
- package/dist/utils/clientUtils.js.map +1 -0
- package/dist/utils/feedUtils.js.map +1 -0
- package/dist/utils/githubAuth.js.map +1 -0
- package/dist/utils/githubUtils.js.map +1 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/macroExpressionUtils.js.map +1 -0
- package/dist/utils/osUtils.js.map +1 -0
- package/dist/utils/versionUtils.js.map +1 -0
- package/dist/web/contract/serverContract.js.map +1 -0
- package/dist/web/public/index.html +1 -1
- package/dist/web/public/js/modal/installHandler.js +227 -0
- package/dist/web/public/js/modal/loadingUI.js +74 -0
- package/dist/web/public/js/modal/messageQueue.js +101 -45
- package/dist/web/public/js/modal/modalUI.js +214 -0
- package/{src/web/public/js/modal/versionUtils.js → dist/web/public/js/modal/version.js} +1 -1
- package/dist/web/public/onboard.html +4 -4
- package/dist/web/server.js.map +1 -0
- package/package.json +5 -1
- 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/.roo/rules-code/rules.md +0 -88
- package/dist/core/onboard/InstallOperationManager.d.ts +0 -23
- package/dist/core/onboard/InstallOperationManager.js +0 -144
- 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/GeneralInstaller.ts +0 -133
- 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/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.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
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
import { exec } from 'child_process';
|
|
2
|
-
import { promisify } from 'util';
|
|
3
|
-
import { SUPPORTED_CLIENTS } from '../../metadatas/constants.js';
|
|
4
|
-
import { Logger } from '../../../utils/logger.js';
|
|
5
|
-
import { handleGitHubRelease } from '../../../utils/githubUtils.js';
|
|
6
|
-
import { compareVersions } from '../../../utils/versionUtils.js';
|
|
7
|
-
|
|
8
|
-
const execAsync = promisify(exec);
|
|
9
|
-
|
|
10
|
-
interface ExtensionInfo {
|
|
11
|
-
name: string;
|
|
12
|
-
publisher: string;
|
|
13
|
-
version: string;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export class ExtensionInstaller {
|
|
17
|
-
/**
|
|
18
|
-
* Get VSCode path based on the OS type
|
|
19
|
-
*/
|
|
20
|
-
private static async getVSCodePath(isInsiders: boolean): Promise<string | null> {
|
|
21
|
-
const command = isInsiders ? 'code-insiders' : 'code';
|
|
22
|
-
try {
|
|
23
|
-
if (process.platform === 'win32') {
|
|
24
|
-
// Windows: Check command availability first
|
|
25
|
-
await execAsync(`where ${command}`);
|
|
26
|
-
return command;
|
|
27
|
-
} else if (process.platform === 'darwin') {
|
|
28
|
-
// macOS: Check in both system and user Applications
|
|
29
|
-
const appName = isInsiders ? 'Visual Studio Code - Insiders.app' : 'Visual Studio Code.app';
|
|
30
|
-
const systemPath = `/Applications/${appName}`;
|
|
31
|
-
const userPath = `${process.env.HOME}/Applications/${appName}`;
|
|
32
|
-
|
|
33
|
-
try {
|
|
34
|
-
await execAsync(`test -d "${systemPath}"`);
|
|
35
|
-
return systemPath;
|
|
36
|
-
} catch {
|
|
37
|
-
try {
|
|
38
|
-
await execAsync(`test -d "${userPath}"`);
|
|
39
|
-
return userPath;
|
|
40
|
-
} catch {
|
|
41
|
-
return null;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
return command;
|
|
46
|
-
} catch {
|
|
47
|
-
return null;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* List installed extensions for VSCode or VSCode Insiders
|
|
53
|
-
*/
|
|
54
|
-
private static async listExtensions(isInsiders: boolean): Promise<ExtensionInfo[]> {
|
|
55
|
-
const command = isInsiders ? 'code-insiders' : 'code';
|
|
56
|
-
try {
|
|
57
|
-
const { stdout } = await execAsync(`${command} --list-extensions --show-versions`);
|
|
58
|
-
return stdout.split('\n')
|
|
59
|
-
.filter(line => line.trim())
|
|
60
|
-
.map(line => {
|
|
61
|
-
const [extension, version] = line.split('@');
|
|
62
|
-
const [publisher, name] = extension.split('.');
|
|
63
|
-
return { name, publisher, version: version || '' };
|
|
64
|
-
});
|
|
65
|
-
} catch (error) {
|
|
66
|
-
Logger.error(`Failed to list extensions for ${command}:`, error);
|
|
67
|
-
return [];
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Check if an extension is installed and get its version
|
|
73
|
-
*/
|
|
74
|
-
private static async checkExtension(extensionId: string, isInsiders: boolean): Promise<string | null> {
|
|
75
|
-
const extensions = await this.listExtensions(isInsiders);
|
|
76
|
-
const [publisher, name] = extensionId.split('.');
|
|
77
|
-
const extension = extensions.find(ext =>
|
|
78
|
-
ext.publisher.toLowerCase() === publisher.toLowerCase() &&
|
|
79
|
-
ext.name.toLowerCase() === name.toLowerCase()
|
|
80
|
-
);
|
|
81
|
-
return extension ? extension.version : null;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
* Install extension from marketplace
|
|
86
|
-
*/
|
|
87
|
-
private static async installPublicExtension(extensionId: string, isInsiders: boolean): Promise<boolean> {
|
|
88
|
-
const command = isInsiders ? 'code-insiders' : 'code';
|
|
89
|
-
try {
|
|
90
|
-
await execAsync(`${command} --install-extension ${extensionId}`);
|
|
91
|
-
return true;
|
|
92
|
-
} catch (error) {
|
|
93
|
-
Logger.error(`Failed to install extension ${extensionId}:`, error);
|
|
94
|
-
return false;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* Install extension from VSIX file
|
|
100
|
-
*/
|
|
101
|
-
private static async installPrivateExtension(vsixPath: string, isInsiders: boolean): Promise<boolean> {
|
|
102
|
-
const command = isInsiders ? 'code-insiders' : 'code';
|
|
103
|
-
try {
|
|
104
|
-
await execAsync(`${command} --install-extension "${vsixPath}"`);
|
|
105
|
-
return true;
|
|
106
|
-
} catch (error) {
|
|
107
|
-
Logger.error(`Failed to install extension from VSIX ${vsixPath}:`, error);
|
|
108
|
-
return false;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
/**
|
|
113
|
-
* Install extension for a specific client
|
|
114
|
-
*/
|
|
115
|
-
public static async installExtension(clientName: string): Promise<boolean> {
|
|
116
|
-
const client = SUPPORTED_CLIENTS[clientName];
|
|
117
|
-
if (!client?.extension?.extensionId) {
|
|
118
|
-
Logger.error(`No extension configuration found for client ${clientName}`);
|
|
119
|
-
return false;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
const { extensionId, leastVersion, repository, assetName, private: isPrivate } = client.extension;
|
|
123
|
-
let success = false;
|
|
124
|
-
|
|
125
|
-
// Check both VSCode and VSCode Insiders
|
|
126
|
-
for (const isInsiders of [false, true]) {
|
|
127
|
-
const vscodePath = await this.getVSCodePath(isInsiders);
|
|
128
|
-
if (!vscodePath) {
|
|
129
|
-
Logger.debug(`${isInsiders ? 'VSCode Insiders' : 'VSCode'} not found, skipping...`);
|
|
130
|
-
continue;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
const currentVersion = await this.checkExtension(extensionId, isInsiders);
|
|
134
|
-
|
|
135
|
-
if (!currentVersion || (isPrivate && leastVersion && compareVersions(currentVersion, leastVersion) < 0)) {
|
|
136
|
-
// Extension not installed or needs update (for private extensions)
|
|
137
|
-
if (!isPrivate) {
|
|
138
|
-
// Install public extension from marketplace
|
|
139
|
-
success = await this.installPublicExtension(extensionId, isInsiders);
|
|
140
|
-
} else {
|
|
141
|
-
// Install private extension from GitHub release using latest version
|
|
142
|
-
try {
|
|
143
|
-
if (!repository || !assetName) {
|
|
144
|
-
throw new Error(`Missing repository or assetName for private extension ${extensionId}`);
|
|
145
|
-
}
|
|
146
|
-
const { resolvedPath } = await handleGitHubRelease(
|
|
147
|
-
{ name: extensionId, version: 'latest', type: 'extension' },
|
|
148
|
-
{ repository, assetName }
|
|
149
|
-
);
|
|
150
|
-
success = await this.installPrivateExtension(resolvedPath, isInsiders);
|
|
151
|
-
} catch (error) {
|
|
152
|
-
Logger.error(`Failed to install/update private extension ${extensionId}:`, error);
|
|
153
|
-
continue;
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
} else {
|
|
157
|
-
// Extension already installed and up to date
|
|
158
|
-
Logger.debug(`Extension ${extensionId} is already installed and up to date`);
|
|
159
|
-
success = true;
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
return success;
|
|
164
|
-
}
|
|
165
|
-
}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { BaseClientInstaller } from './BaseClientInstaller.js';
|
|
2
|
-
import { readJsonFile, writeJsonFile } from '../../../utils/clientUtils.js';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Github Copilot client installer implementation
|
|
6
|
-
* Handles installation of Github Copilot client including extension installation and settings configuration
|
|
7
|
-
*/
|
|
8
|
-
export class GithubCopilotInstaller extends BaseClientInstaller {
|
|
9
|
-
protected readonly clientName: string = 'GithubCopilot';
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Initialize settings with GithubCopilot-specific structure
|
|
14
|
-
* Overrides base method to provide custom initialization
|
|
15
|
-
*/
|
|
16
|
-
protected initializeSettings(settings: any): void {
|
|
17
|
-
if (!settings.mcp) {
|
|
18
|
-
settings.mcp = {
|
|
19
|
-
servers: {},
|
|
20
|
-
inputs: []
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (!settings.mcp.servers) {
|
|
25
|
-
settings.mcp.servers = {};
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Handle stdio mode configuration for GithubCopilot
|
|
31
|
-
* Overrides base method to provide custom stdio configuration
|
|
32
|
-
*/
|
|
33
|
-
protected async handleStdioMode(settings: any, serverName: string, finalConfig: any): Promise<void> {
|
|
34
|
-
if (finalConfig.args) {
|
|
35
|
-
finalConfig.args = finalConfig.args.map((arg: string) =>
|
|
36
|
-
typeof arg === 'string' ? arg.replace(/\\/g, '/') : arg
|
|
37
|
-
);
|
|
38
|
-
}
|
|
39
|
-
settings.mcp.servers[serverName] = {
|
|
40
|
-
command: finalConfig.command,
|
|
41
|
-
args: finalConfig.args,
|
|
42
|
-
env: finalConfig.env
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Handle SSE mode configuration for GithubCopilot
|
|
48
|
-
* Overrides base method to provide custom SSE configuration
|
|
49
|
-
*/
|
|
50
|
-
protected handleSseMode(settings: any, serverName: string, installConfig: any): void {
|
|
51
|
-
settings.mcp.servers[serverName] = {
|
|
52
|
-
type: 'sse',
|
|
53
|
-
url: installConfig.url
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* Set up Github Copilot client settings
|
|
59
|
-
* Updates VS Code settings with MCP server configuration
|
|
60
|
-
* Note: GithubCopilot uses a different settings structure compared to other clients
|
|
61
|
-
*/
|
|
62
|
-
async setupClientSettings(settingPath: string, serverName: string, installConfig: any): Promise<void> {
|
|
63
|
-
// Read existing settings
|
|
64
|
-
const settings = await readJsonFile(settingPath, true);
|
|
65
|
-
|
|
66
|
-
// Initialize settings with client-specific structure
|
|
67
|
-
this.initializeSettings(settings);
|
|
68
|
-
|
|
69
|
-
// Handle different modes
|
|
70
|
-
if (installConfig.mode === 'stdio') {
|
|
71
|
-
await this.handleStdioMode(settings, serverName, installConfig);
|
|
72
|
-
} else if (installConfig.mode === 'sse') {
|
|
73
|
-
this.handleSseMode(settings, serverName, installConfig);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
// Write updated settings
|
|
77
|
-
await writeJsonFile(settingPath, settings);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { BaseClientInstaller } from './BaseClientInstaller.js';
|
|
2
|
-
import { readJsonFile, writeJsonFile } from '../../../utils/clientUtils.js';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* MSRooCode client installer implementation
|
|
6
|
-
*/
|
|
7
|
-
export class MSRooCodeInstaller extends BaseClientInstaller {
|
|
8
|
-
protected readonly clientName: string = 'MSRooCode';
|
|
9
|
-
/**
|
|
10
|
-
* Set up MSRooCode client settings
|
|
11
|
-
*/
|
|
12
|
-
async setupClientSettings(settingPath: string, serverName: string, installConfig: any): Promise<void> {
|
|
13
|
-
// Read existing settings
|
|
14
|
-
const settings = await readJsonFile(settingPath, true);
|
|
15
|
-
|
|
16
|
-
// Initialize settings with client-specific structure
|
|
17
|
-
this.initializeSettings(settings);
|
|
18
|
-
|
|
19
|
-
// Handle different modes
|
|
20
|
-
if (installConfig.mode === 'stdio') {
|
|
21
|
-
// Process config for Windows NPX if needed
|
|
22
|
-
const finalConfig = await this.handleWindowsNpx(installConfig);
|
|
23
|
-
|
|
24
|
-
await this.handleStdioMode(settings, serverName, finalConfig);
|
|
25
|
-
} else if (installConfig.mode === 'sse') {
|
|
26
|
-
this.handleSseMode(settings, serverName, installConfig);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
// Write updated settings
|
|
30
|
-
await writeJsonFile(settingPath, settings);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
// Export the interface
|
|
2
|
-
export { RequirementInstaller } from './requirements/RequirementInstaller.js';
|
|
3
|
-
export { ClientInstaller } from './clients/ClientInstaller.js';
|
|
4
|
-
|
|
5
|
-
// Export all requirement installer implementations
|
|
6
|
-
export { BaseInstaller } from './requirements/BaseInstaller.js';
|
|
7
|
-
export { NpmInstaller } from './requirements/NpmInstaller.js';
|
|
8
|
-
export { PipInstaller } from './requirements/PipInstaller.js';
|
|
9
|
-
export { GeneralInstaller } from './requirements/GeneralInstaller.js';
|
|
10
|
-
export { CommandInstaller } from './requirements/CommandInstaller.js';
|
|
11
|
-
export { InstallerFactory, createInstallerFactory } from './requirements/InstallerFactory.js';
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import { RequirementConfig, RequirementStatus, RegistryConfig, ServerInstallOptions } from '../../metadatas/types.js';
|
|
2
|
-
import path from 'path';
|
|
3
|
-
import { SETTINGS_DIR } from '../../metadatas/constants.js';
|
|
4
|
-
import { RequirementInstaller } from './RequirementInstaller.js';
|
|
5
|
-
import { Logger } from '../../../utils/logger.js';
|
|
6
|
-
import { InstallOperationManager } from '../../loaders/InstallOperationManager.js';
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Abstract base class with common functionality for all requirement installers
|
|
10
|
-
*/
|
|
11
|
-
export abstract class BaseInstaller implements RequirementInstaller {
|
|
12
|
-
protected execPromise: (command: string) => Promise<{ stdout: string; stderr: string }>;
|
|
13
|
-
protected downloadsDir: string;
|
|
14
|
-
|
|
15
|
-
constructor(execPromise: (command: string) => Promise<{ stdout: string; stderr: string }>) {
|
|
16
|
-
this.execPromise = execPromise;
|
|
17
|
-
this.downloadsDir = path.join(SETTINGS_DIR, 'downloads');
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
abstract canHandle(requirement: RequirementConfig): boolean;
|
|
21
|
-
abstract supportCheckUpdates(): boolean;
|
|
22
|
-
/**
|
|
23
|
-
* Install the requirement
|
|
24
|
-
* @param requirement The requirement to install
|
|
25
|
-
* @param options Optional install options
|
|
26
|
-
* @param recorder Optional InstallOperationManager for recording steps
|
|
27
|
-
* @returns The status of the installation
|
|
28
|
-
*/
|
|
29
|
-
abstract install(requirement: RequirementConfig, recorder: InstallOperationManager, options?: ServerInstallOptions): Promise<RequirementStatus>;
|
|
30
|
-
abstract checkInstallation(requirement: RequirementConfig, options?: ServerInstallOptions): Promise<RequirementStatus>;
|
|
31
|
-
/**
|
|
32
|
-
* Get the latest version available for the requirement.
|
|
33
|
-
* This method needs to be implemented by concrete installers.
|
|
34
|
-
* @param requirement The requirement to check.
|
|
35
|
-
* @param options Optional server install options.
|
|
36
|
-
* @returns The latest version string, or undefined if not found or not applicable.
|
|
37
|
-
*/
|
|
38
|
-
abstract getLatestVersion(requirement: RequirementConfig, options?: ServerInstallOptions): Promise<string | undefined>;
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Check if updates are available for the requirement
|
|
43
|
-
* @param requirement The requirement to check
|
|
44
|
-
* @param currentStatus The current status of the requirement
|
|
45
|
-
* @param options Optional server install options.
|
|
46
|
-
* @returns The status of the requirement with update information
|
|
47
|
-
*/
|
|
48
|
-
async checkForUpdates(requirement: RequirementConfig, currentStatus: RequirementStatus, options?: ServerInstallOptions): Promise<RequirementStatus> {
|
|
49
|
-
try {
|
|
50
|
-
// If requirement is not installed, no need to check for updates
|
|
51
|
-
if (!currentStatus.installed) {
|
|
52
|
-
return currentStatus;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// If the version doesn't contain "latest", no update check needed
|
|
56
|
-
if (!requirement.version.includes('latest')) {
|
|
57
|
-
return currentStatus;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
const latestVersion = await this.getLatestVersion(requirement, options);
|
|
61
|
-
|
|
62
|
-
// If we found a latest version and it's different from current
|
|
63
|
-
if (latestVersion && latestVersion !== currentStatus.version) {
|
|
64
|
-
return {
|
|
65
|
-
...currentStatus,
|
|
66
|
-
availableUpdate: {
|
|
67
|
-
version: latestVersion,
|
|
68
|
-
message: `Update available: ${currentStatus.version} → ${latestVersion}`
|
|
69
|
-
},
|
|
70
|
-
lastCheckTime: new Date().toISOString()
|
|
71
|
-
};
|
|
72
|
-
} else {
|
|
73
|
-
return {
|
|
74
|
-
...currentStatus,
|
|
75
|
-
lastCheckTime: new Date().toISOString()
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
} catch (error) {
|
|
80
|
-
// Don't update status on error, just log it
|
|
81
|
-
Logger.log(`Error checking for updates for ${requirement.name}: ${error instanceof Error ? error.message : String(error)}`);
|
|
82
|
-
return currentStatus;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { RequirementConfig, RequirementStatus, ServerInstallOptions } from '../../metadatas/types.js';
|
|
2
|
-
import { BaseInstaller } from './BaseInstaller.js';
|
|
3
|
-
import { handleGitHubRelease } from '../../../utils/githubUtils.js';
|
|
4
|
-
import { handleArtifact } from '../../../utils/adoUtils.js';
|
|
5
|
-
import { InstallOperationManager } from '../../loaders/InstallOperationManager.js';
|
|
6
|
-
import * as RecordingConstants from '../../metadatas/recordingConstants.js';
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Installer implementation for general requirements (type 'other')
|
|
10
|
-
* This installer handles requirements that don't fit into specific package manager categories
|
|
11
|
-
*/
|
|
12
|
-
export class GeneralInstaller extends BaseInstaller {
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Constructor for the GeneralInstaller
|
|
16
|
-
* @param execPromise Function to execute commands
|
|
17
|
-
*/
|
|
18
|
-
getLatestVersion(requirement: RequirementConfig, options?: ServerInstallOptions): Promise<string | undefined> {
|
|
19
|
-
throw new Error('Method not implemented.');
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Check if this installer can handle the given requirement type
|
|
23
|
-
* @param requirement The requirement to check
|
|
24
|
-
* @returns True if this installer can handle the requirement
|
|
25
|
-
*/
|
|
26
|
-
canHandle(requirement: RequirementConfig): boolean {
|
|
27
|
-
return requirement.type === 'other';
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
supportCheckUpdates(): boolean {
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Check if the requirement is already installed
|
|
35
|
-
* For general installers, we can't easily check if something is installed
|
|
36
|
-
* without specific knowledge of the requirement, so we always return false
|
|
37
|
-
*
|
|
38
|
-
* @param requirement The requirement to check
|
|
39
|
-
* @returns The status of the requirement
|
|
40
|
-
*/
|
|
41
|
-
async checkInstallation(requirement: RequirementConfig): Promise<RequirementStatus> {
|
|
42
|
-
// For general installers, we can't easily check if something is installed
|
|
43
|
-
// So we'll always return not installed, and the actual installation will check
|
|
44
|
-
return {
|
|
45
|
-
name: requirement.name,
|
|
46
|
-
type: 'other',
|
|
47
|
-
installed: false,
|
|
48
|
-
inProgress: false
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Install the general requirement
|
|
54
|
-
* For type 'other', this doesn't actually install anything, but downloads
|
|
55
|
-
* or locates the asset and returns the path for the caller to use
|
|
56
|
-
*
|
|
57
|
-
* @param requirement The requirement to install
|
|
58
|
-
* @returns The status of the installation, including the install path in updateInfo
|
|
59
|
-
*/
|
|
60
|
-
/**
|
|
61
|
-
* Install the general requirement
|
|
62
|
-
* For type 'other', this doesn't actually install anything, but downloads
|
|
63
|
-
* or locates the asset and returns the path for the caller to use
|
|
64
|
-
* @param requirement The requirement to install
|
|
65
|
-
* @param options Optional install options
|
|
66
|
-
* @param recorder Optional InstallOperationManager for recording steps
|
|
67
|
-
* @returns The status of the installation, including the install path in updateInfo
|
|
68
|
-
*/
|
|
69
|
-
async install(requirement: RequirementConfig, recorder: InstallOperationManager, options?: ServerInstallOptions): Promise<RequirementStatus> {
|
|
70
|
-
const doInstall = async (): Promise<RequirementStatus> => {
|
|
71
|
-
// For type 'other', a registry must be specified
|
|
72
|
-
if (!requirement.registry) {
|
|
73
|
-
throw new Error('Registry must be specified for requirement type "other"');
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
let installPath: string;
|
|
77
|
-
|
|
78
|
-
if (requirement.registry.githubRelease) {
|
|
79
|
-
const result = await handleGitHubRelease(requirement, requirement.registry.githubRelease);
|
|
80
|
-
installPath = result.resolvedPath;
|
|
81
|
-
} else if (requirement.registry.artifacts) {
|
|
82
|
-
await handleArtifact(requirement, requirement.registry.artifacts);
|
|
83
|
-
} else {
|
|
84
|
-
throw new Error('Invalid registry configuration');
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
// For general installer, we just return the path to the downloaded/located file
|
|
88
|
-
// The actual installation mechanism would depend on the specific requirement
|
|
89
|
-
return {
|
|
90
|
-
name: requirement.name,
|
|
91
|
-
type: 'other',
|
|
92
|
-
installed: true,
|
|
93
|
-
version: requirement.version,
|
|
94
|
-
inProgress: false,
|
|
95
|
-
};
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
if (recorder) {
|
|
99
|
-
return recorder.recording(doInstall, {
|
|
100
|
-
stepName: RecordingConstants.STEP_GENERAL_INSTALLER_INSTALL,
|
|
101
|
-
inProgressMessage: `Installing general requirement: ${requirement.name}`,
|
|
102
|
-
endMessage: (result) =>
|
|
103
|
-
result.installed
|
|
104
|
-
? `Install completed for ${requirement.name}`
|
|
105
|
-
: `Install failed for ${requirement.name}`,
|
|
106
|
-
onError: (error) => {
|
|
107
|
-
return {
|
|
108
|
-
result: {
|
|
109
|
-
name: requirement.name,
|
|
110
|
-
type: 'other',
|
|
111
|
-
installed: false,
|
|
112
|
-
error: error instanceof Error ? error.message : String(error),
|
|
113
|
-
inProgress: false,
|
|
114
|
-
},
|
|
115
|
-
message: error instanceof Error ? error.message : String(error),
|
|
116
|
-
};
|
|
117
|
-
},
|
|
118
|
-
});
|
|
119
|
-
} else {
|
|
120
|
-
try {
|
|
121
|
-
return await doInstall();
|
|
122
|
-
} catch (error) {
|
|
123
|
-
return {
|
|
124
|
-
name: requirement.name,
|
|
125
|
-
type: 'other',
|
|
126
|
-
installed: false,
|
|
127
|
-
error: error instanceof Error ? error.message : String(error),
|
|
128
|
-
inProgress: false,
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
}
|