imcp 0.1.3 → 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.
Files changed (239) hide show
  1. package/README.md +21 -4
  2. package/dist/cli/commands/install.js.map +1 -0
  3. package/dist/cli/commands/list.js.map +1 -0
  4. package/dist/cli/commands/pull.js.map +1 -0
  5. package/dist/cli/commands/serve.js.map +1 -0
  6. package/dist/cli/commands/start.d.ts +2 -0
  7. package/dist/cli/commands/start.js +32 -0
  8. package/dist/cli/commands/start.js.map +1 -0
  9. package/dist/cli/commands/sync.d.ts +2 -0
  10. package/dist/cli/commands/sync.js +17 -0
  11. package/dist/cli/commands/sync.js.map +1 -0
  12. package/dist/cli/commands/uninstall.js.map +1 -0
  13. package/dist/cli/index.js +0 -0
  14. package/dist/cli/index.js.map +1 -0
  15. package/dist/core/ConfigurationLoader.d.ts +32 -0
  16. package/{src/core/loaders/ConfigurationLoader.ts → dist/core/ConfigurationLoader.js} +236 -298
  17. package/dist/core/ConfigurationLoader.js.map +1 -0
  18. package/dist/core/ConfigurationProvider.d.ts +35 -0
  19. package/{src/core/loaders/ConfigurationProvider.ts → dist/core/ConfigurationProvider.js} +375 -462
  20. package/dist/core/ConfigurationProvider.js.map +1 -0
  21. package/dist/core/InstallationService.d.ts +50 -0
  22. package/dist/core/InstallationService.js +350 -0
  23. package/dist/core/InstallationService.js.map +1 -0
  24. package/dist/core/MCPManager.d.ts +28 -0
  25. package/dist/core/MCPManager.js +188 -0
  26. package/dist/core/MCPManager.js.map +1 -0
  27. package/dist/core/RequirementService.d.ts +40 -0
  28. package/dist/core/RequirementService.js +110 -0
  29. package/dist/core/RequirementService.js.map +1 -0
  30. package/dist/core/ServerSchemaLoader.d.ts +11 -0
  31. package/dist/core/ServerSchemaLoader.js +43 -0
  32. package/dist/core/ServerSchemaLoader.js.map +1 -0
  33. package/dist/core/ServerSchemaProvider.d.ts +17 -0
  34. package/dist/core/ServerSchemaProvider.js +120 -0
  35. package/dist/core/ServerSchemaProvider.js.map +1 -0
  36. package/dist/core/constants.d.ts +47 -0
  37. package/dist/core/constants.js +94 -0
  38. package/dist/core/constants.js.map +1 -0
  39. package/dist/core/installers/BaseInstaller.d.ts +74 -0
  40. package/dist/core/installers/BaseInstaller.js +253 -0
  41. package/dist/core/installers/BaseInstaller.js.map +1 -0
  42. package/dist/core/installers/ClientInstaller.d.ts +23 -0
  43. package/dist/core/installers/ClientInstaller.js +564 -0
  44. package/dist/core/installers/ClientInstaller.js.map +1 -0
  45. package/dist/core/installers/CommandInstaller.d.ts +37 -0
  46. package/{src/core/installers/requirements/CommandInstaller.ts → dist/core/installers/CommandInstaller.js} +173 -231
  47. package/dist/core/installers/CommandInstaller.js.map +1 -0
  48. package/dist/core/installers/GeneralInstaller.d.ts +33 -0
  49. package/dist/core/installers/GeneralInstaller.js +85 -0
  50. package/dist/core/installers/GeneralInstaller.js.map +1 -0
  51. package/dist/core/installers/InstallerFactory.d.ts +54 -0
  52. package/{src/core/installers/requirements/InstallerFactory.ts → dist/core/installers/InstallerFactory.js} +97 -112
  53. package/dist/core/installers/InstallerFactory.js.map +1 -0
  54. package/dist/core/installers/NpmInstaller.d.ts +26 -0
  55. package/dist/core/installers/NpmInstaller.js +127 -0
  56. package/dist/core/installers/NpmInstaller.js.map +1 -0
  57. package/dist/core/installers/PipInstaller.d.ts +28 -0
  58. package/dist/core/installers/PipInstaller.js +127 -0
  59. package/dist/core/installers/PipInstaller.js.map +1 -0
  60. package/{src/core/installers/requirements/RequirementInstaller.ts → dist/core/installers/RequirementInstaller.d.ts} +33 -42
  61. package/dist/core/installers/RequirementInstaller.js +3 -0
  62. package/dist/core/installers/RequirementInstaller.js.map +1 -0
  63. package/dist/core/installers/clients/BaseClientInstaller.js.map +1 -0
  64. package/dist/core/installers/clients/ClientInstaller.js.map +1 -0
  65. package/dist/core/installers/clients/ClientInstallerFactory.js.map +1 -0
  66. package/dist/core/installers/clients/ClineInstaller.js.map +1 -0
  67. package/dist/core/installers/clients/ExtensionInstaller.js.map +1 -0
  68. package/dist/core/installers/clients/GithubCopilotInstaller.js.map +1 -0
  69. package/dist/core/installers/clients/MSRooCodeInstaller.js.map +1 -0
  70. package/dist/core/installers/index.js.map +1 -0
  71. package/dist/core/installers/requirements/BaseInstaller.js.map +1 -0
  72. package/dist/core/installers/requirements/CommandInstaller.js.map +1 -0
  73. package/dist/core/installers/requirements/GeneralInstaller.js.map +1 -0
  74. package/dist/core/installers/requirements/InstallerFactory.js +2 -0
  75. package/dist/core/installers/requirements/InstallerFactory.js.map +1 -0
  76. package/dist/core/installers/requirements/NpmInstaller.js.map +1 -0
  77. package/dist/core/installers/requirements/NugetInstaller.d.ts +37 -0
  78. package/dist/core/installers/requirements/NugetInstaller.js +189 -0
  79. package/dist/core/installers/requirements/NugetInstaller.js.map +1 -0
  80. package/dist/core/installers/requirements/PipInstaller.js.map +1 -0
  81. package/dist/core/installers/requirements/RequirementInstaller.js.map +1 -0
  82. package/dist/core/loaders/ConfigurationLoader.js.map +1 -0
  83. package/dist/core/loaders/ConfigurationProvider.js.map +1 -0
  84. package/dist/core/loaders/InstallOperationManager.js.map +1 -0
  85. package/dist/core/loaders/ServerSchemaLoader.js.map +1 -0
  86. package/dist/core/loaders/ServerSchemaProvider.js.map +1 -0
  87. package/dist/core/loaders/SystemSettingsManager.js.map +1 -0
  88. package/dist/core/metadatas/constants.js.map +1 -0
  89. package/dist/core/metadatas/recordingConstants.d.ts +2 -0
  90. package/dist/core/metadatas/recordingConstants.js +2 -0
  91. package/dist/core/metadatas/recordingConstants.js.map +1 -0
  92. package/dist/core/metadatas/types.d.ts +1 -1
  93. package/dist/core/metadatas/types.js.map +1 -0
  94. package/dist/core/onboard/FeedOnboardService.js +1 -22
  95. package/dist/core/onboard/FeedOnboardService.js.map +1 -0
  96. package/dist/core/onboard/OnboardProcessor.js.map +1 -0
  97. package/dist/core/onboard/OnboardStatus.js.map +1 -0
  98. package/dist/core/onboard/OnboardStatusManager.js.map +1 -0
  99. package/dist/core/types.d.ts +166 -0
  100. package/dist/core/types.js +16 -0
  101. package/dist/core/types.js.map +1 -0
  102. package/dist/core/validators/FeedValidator.js.map +1 -0
  103. package/dist/core/validators/IServerValidator.js.map +1 -0
  104. package/dist/core/validators/SSEServerValidator.js.map +1 -0
  105. package/dist/core/validators/ServerValidatorFactory.js.map +1 -0
  106. package/dist/core/validators/StdioServerValidator.js +5 -5
  107. package/dist/core/validators/StdioServerValidator.js.map +1 -0
  108. package/dist/index.js.map +1 -0
  109. package/dist/services/InstallRequestValidator.d.ts +21 -0
  110. package/dist/services/InstallRequestValidator.js +99 -0
  111. package/dist/services/InstallRequestValidator.js.map +1 -0
  112. package/dist/services/InstallationService.js.map +1 -0
  113. package/dist/services/MCPManager.js.map +1 -0
  114. package/dist/services/RequirementService.js.map +1 -0
  115. package/dist/services/ServerService.js.map +1 -0
  116. package/dist/services/TelemetryService.js.map +1 -0
  117. package/dist/utils/UpdateCheckTracker.js.map +1 -0
  118. package/dist/utils/adoUtils.js.map +1 -0
  119. package/dist/utils/clientUtils.js.map +1 -0
  120. package/dist/utils/feedUtils.js.map +1 -0
  121. package/dist/utils/githubAuth.js.map +1 -0
  122. package/dist/utils/githubUtils.js.map +1 -0
  123. package/dist/utils/logger.js.map +1 -0
  124. package/dist/utils/macroExpressionUtils.js.map +1 -0
  125. package/dist/utils/osUtils.d.ts +11 -0
  126. package/dist/utils/osUtils.js +100 -0
  127. package/dist/utils/osUtils.js.map +1 -0
  128. package/dist/utils/versionUtils.js.map +1 -0
  129. package/dist/web/contract/serverContract.js.map +1 -0
  130. package/dist/web/public/index.html +1 -1
  131. package/dist/web/public/js/modal/installHandler.js +227 -0
  132. package/dist/web/public/js/modal/loadingUI.js +74 -0
  133. package/dist/web/public/js/modal/messageQueue.js +101 -45
  134. package/dist/web/public/js/modal/modalUI.js +214 -0
  135. package/{src/web/public/js/modal/versionUtils.js → dist/web/public/js/modal/version.js} +1 -1
  136. package/dist/web/public/js/onboard/templates.js +1 -0
  137. package/dist/web/public/js/serverCategoryList.js +3 -3
  138. package/dist/web/public/onboard.html +4 -4
  139. package/dist/web/server.js.map +1 -0
  140. package/package.json +5 -1
  141. package/.github/ISSUE_TEMPLATE/JitAccess.yml +0 -28
  142. package/.github/acl/access.yml +0 -20
  143. package/.github/compliance/inventory.yml +0 -5
  144. package/.github/policies/jit.yml +0 -19
  145. package/.roo/rules-code/rules.md +0 -88
  146. package/dist/core/onboard/InstallOperationManager.d.ts +0 -23
  147. package/dist/core/onboard/InstallOperationManager.js +0 -144
  148. package/docs/ONBOARDING_PAGE_DESIGN.md +0 -260
  149. package/docs/Telemetry.md +0 -136
  150. package/memory-bank/activeContext.md +0 -26
  151. package/memory-bank/decisionLog.md +0 -91
  152. package/memory-bank/productContext.md +0 -41
  153. package/memory-bank/progress.md +0 -35
  154. package/memory-bank/systemPatterns.md +0 -10
  155. package/src/cli/commands/install.ts +0 -139
  156. package/src/cli/commands/list.ts +0 -113
  157. package/src/cli/commands/pull.ts +0 -16
  158. package/src/cli/commands/serve.ts +0 -39
  159. package/src/cli/commands/uninstall.ts +0 -64
  160. package/src/cli/index.ts +0 -82
  161. package/src/core/installers/clients/BaseClientInstaller.ts +0 -341
  162. package/src/core/installers/clients/ClientInstaller.ts +0 -222
  163. package/src/core/installers/clients/ClientInstallerFactory.ts +0 -43
  164. package/src/core/installers/clients/ClineInstaller.ts +0 -35
  165. package/src/core/installers/clients/ExtensionInstaller.ts +0 -165
  166. package/src/core/installers/clients/GithubCopilotInstaller.ts +0 -79
  167. package/src/core/installers/clients/MSRooCodeInstaller.ts +0 -32
  168. package/src/core/installers/index.ts +0 -11
  169. package/src/core/installers/requirements/BaseInstaller.ts +0 -85
  170. package/src/core/installers/requirements/GeneralInstaller.ts +0 -133
  171. package/src/core/installers/requirements/NpmInstaller.ts +0 -271
  172. package/src/core/installers/requirements/PipInstaller.ts +0 -207
  173. package/src/core/loaders/InstallOperationManager.ts +0 -367
  174. package/src/core/loaders/ServerSchemaLoader.ts +0 -117
  175. package/src/core/loaders/ServerSchemaProvider.ts +0 -99
  176. package/src/core/loaders/SystemSettingsManager.ts +0 -278
  177. package/src/core/metadatas/constants.ts +0 -122
  178. package/src/core/metadatas/recordingConstants.ts +0 -62
  179. package/src/core/metadatas/types.ts +0 -202
  180. package/src/core/onboard/FeedOnboardService.ts +0 -524
  181. package/src/core/onboard/OnboardProcessor.ts +0 -356
  182. package/src/core/onboard/OnboardStatus.ts +0 -60
  183. package/src/core/onboard/OnboardStatusManager.ts +0 -416
  184. package/src/core/validators/FeedValidator.ts +0 -135
  185. package/src/core/validators/IServerValidator.ts +0 -21
  186. package/src/core/validators/SSEServerValidator.ts +0 -43
  187. package/src/core/validators/ServerValidatorFactory.ts +0 -51
  188. package/src/core/validators/StdioServerValidator.ts +0 -312
  189. package/src/index.ts +0 -44
  190. package/src/services/InstallationService.ts +0 -102
  191. package/src/services/MCPManager.ts +0 -249
  192. package/src/services/RequirementService.ts +0 -627
  193. package/src/services/ServerService.ts +0 -161
  194. package/src/services/TelemetryService.ts +0 -59
  195. package/src/utils/UpdateCheckTracker.ts +0 -86
  196. package/src/utils/adoUtils.ts +0 -293
  197. package/src/utils/clientUtils.ts +0 -72
  198. package/src/utils/feedUtils.ts +0 -31
  199. package/src/utils/githubAuth.ts +0 -212
  200. package/src/utils/githubUtils.ts +0 -164
  201. package/src/utils/logger.ts +0 -195
  202. package/src/utils/macroExpressionUtils.ts +0 -104
  203. package/src/utils/osUtils.ts +0 -597
  204. package/src/utils/versionUtils.ts +0 -114
  205. package/src/web/contract/serverContract.ts +0 -74
  206. package/src/web/public/css/detailsWidget.css +0 -235
  207. package/src/web/public/css/modal.css +0 -757
  208. package/src/web/public/css/notifications.css +0 -101
  209. package/src/web/public/css/onboard.css +0 -107
  210. package/src/web/public/css/serverCategoryList.css +0 -120
  211. package/src/web/public/css/serverDetails.css +0 -139
  212. package/src/web/public/index.html +0 -359
  213. package/src/web/public/js/api.js +0 -132
  214. package/src/web/public/js/detailsWidget.js +0 -264
  215. package/src/web/public/js/flights/flights.js +0 -127
  216. package/src/web/public/js/modal/index.js +0 -52
  217. package/src/web/public/js/modal/installModal.js +0 -162
  218. package/src/web/public/js/modal/installation.js +0 -266
  219. package/src/web/public/js/modal/loadingModal.js +0 -182
  220. package/src/web/public/js/modal/modalSetup.js +0 -595
  221. package/src/web/public/js/modal/modalUtils.js +0 -37
  222. package/src/web/public/js/modal.js +0 -42
  223. package/src/web/public/js/notifications.js +0 -137
  224. package/src/web/public/js/onboard/formProcessor.js +0 -1037
  225. package/src/web/public/js/onboard/index.js +0 -374
  226. package/src/web/public/js/onboard/publishHandler.js +0 -172
  227. package/src/web/public/js/onboard/state.js +0 -76
  228. package/src/web/public/js/onboard/templates.js +0 -341
  229. package/src/web/public/js/onboard/uiHandlers.js +0 -1076
  230. package/src/web/public/js/onboard/validationHandlers.js +0 -493
  231. package/src/web/public/js/serverCategoryDetails.js +0 -364
  232. package/src/web/public/js/serverCategoryList.js +0 -241
  233. package/src/web/public/js/settings.js +0 -314
  234. package/src/web/public/modal.html +0 -84
  235. package/src/web/public/onboard.html +0 -296
  236. package/src/web/public/settings.html +0 -135
  237. package/src/web/public/styles.css +0 -277
  238. package/src/web/server.ts +0 -478
  239. 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
- }