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