mcp4openapi 0.2.8 → 0.3.1

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 (358) hide show
  1. package/README.md +143 -63
  2. package/dist/scripts/validate-profile.js +3 -3
  3. package/dist/scripts/validate-profile.js.map +1 -1
  4. package/dist/src/argument-normalizer.d.ts +5 -0
  5. package/dist/src/argument-normalizer.d.ts.map +1 -0
  6. package/dist/src/argument-normalizer.js +61 -0
  7. package/dist/src/argument-normalizer.js.map +1 -0
  8. package/dist/src/auth/oauth-provider.d.ts +131 -0
  9. package/dist/src/auth/oauth-provider.d.ts.map +1 -0
  10. package/dist/src/auth/oauth-provider.js +839 -0
  11. package/dist/src/auth/oauth-provider.js.map +1 -0
  12. package/dist/src/cli-config.d.ts +9 -0
  13. package/dist/src/cli-config.d.ts.map +1 -0
  14. package/dist/src/cli-config.js +111 -0
  15. package/dist/src/cli-config.js.map +1 -0
  16. package/dist/src/core/cli-config.d.ts +9 -0
  17. package/dist/src/core/cli-config.d.ts.map +1 -0
  18. package/dist/src/core/cli-config.js +125 -0
  19. package/dist/src/core/cli-config.js.map +1 -0
  20. package/dist/src/core/constants.d.ts +86 -0
  21. package/dist/src/core/constants.d.ts.map +1 -0
  22. package/dist/src/core/constants.js +86 -0
  23. package/dist/src/core/constants.js.map +1 -0
  24. package/dist/src/core/errors.d.ts +59 -0
  25. package/dist/src/core/errors.d.ts.map +1 -0
  26. package/dist/src/core/errors.js +119 -0
  27. package/dist/src/core/errors.js.map +1 -0
  28. package/dist/src/core/filtering.d.ts +19 -0
  29. package/dist/src/core/filtering.d.ts.map +1 -0
  30. package/dist/src/core/filtering.js +292 -0
  31. package/dist/src/core/filtering.js.map +1 -0
  32. package/dist/src/core/index.d.ts +26 -0
  33. package/dist/src/core/index.d.ts.map +1 -0
  34. package/dist/src/core/index.js +276 -0
  35. package/dist/src/core/index.js.map +1 -0
  36. package/dist/src/core/lib.d.ts +8 -0
  37. package/dist/src/core/lib.d.ts.map +1 -0
  38. package/dist/src/core/lib.js +7 -0
  39. package/dist/src/core/lib.js.map +1 -0
  40. package/dist/src/core/logger.d.ts +59 -0
  41. package/dist/src/core/logger.d.ts.map +1 -0
  42. package/dist/src/core/logger.js +197 -0
  43. package/dist/src/core/logger.js.map +1 -0
  44. package/dist/src/core/metrics.d.ts +97 -0
  45. package/dist/src/core/metrics.d.ts.map +1 -0
  46. package/dist/src/core/metrics.js +273 -0
  47. package/dist/src/core/metrics.js.map +1 -0
  48. package/dist/src/core/naming-warnings.d.ts +23 -0
  49. package/dist/src/core/naming-warnings.d.ts.map +1 -0
  50. package/dist/src/core/naming-warnings.js +83 -0
  51. package/dist/src/core/naming-warnings.js.map +1 -0
  52. package/dist/src/core/naming.d.ts +58 -0
  53. package/dist/src/core/naming.d.ts.map +1 -0
  54. package/dist/src/core/naming.js +510 -0
  55. package/dist/src/core/naming.js.map +1 -0
  56. package/dist/src/errors.d.ts +6 -0
  57. package/dist/src/errors.d.ts.map +1 -1
  58. package/dist/src/errors.js +15 -6
  59. package/dist/src/errors.js.map +1 -1
  60. package/dist/src/filtering.d.ts +19 -0
  61. package/dist/src/filtering.d.ts.map +1 -0
  62. package/dist/src/filtering.js +292 -0
  63. package/dist/src/filtering.js.map +1 -0
  64. package/dist/src/generated-schemas.d.ts +290 -79
  65. package/dist/src/generated-schemas.d.ts.map +1 -1
  66. package/dist/src/generated-schemas.js +17 -2
  67. package/dist/src/generated-schemas.js.map +1 -1
  68. package/dist/src/http-transport-config.d.ts +6 -0
  69. package/dist/src/http-transport-config.d.ts.map +1 -0
  70. package/dist/src/http-transport-config.js +47 -0
  71. package/dist/src/http-transport-config.js.map +1 -0
  72. package/dist/src/http-transport.d.ts +63 -13
  73. package/dist/src/http-transport.d.ts.map +1 -1
  74. package/dist/src/http-transport.js +1045 -482
  75. package/dist/src/http-transport.js.map +1 -1
  76. package/dist/src/index.d.ts +1 -6
  77. package/dist/src/index.d.ts.map +1 -1
  78. package/dist/src/index.js +1 -170
  79. package/dist/src/index.js.map +1 -1
  80. package/dist/src/interceptors.d.ts +1 -0
  81. package/dist/src/interceptors.d.ts.map +1 -1
  82. package/dist/src/interceptors.js +73 -63
  83. package/dist/src/interceptors.js.map +1 -1
  84. package/dist/src/lib.d.ts +1 -7
  85. package/dist/src/lib.d.ts.map +1 -1
  86. package/dist/src/lib.js +1 -6
  87. package/dist/src/lib.js.map +1 -1
  88. package/dist/src/logger.d.ts +5 -0
  89. package/dist/src/logger.d.ts.map +1 -1
  90. package/dist/src/logger.js +9 -1
  91. package/dist/src/logger.js.map +1 -1
  92. package/dist/src/mcp/mcp-server-manager.d.ts +20 -0
  93. package/dist/src/mcp/mcp-server-manager.d.ts.map +1 -0
  94. package/dist/src/mcp/mcp-server-manager.js +38 -0
  95. package/dist/src/mcp/mcp-server-manager.js.map +1 -0
  96. package/dist/src/mcp/mcp-server.d.ts +205 -0
  97. package/dist/src/mcp/mcp-server.d.ts.map +1 -0
  98. package/dist/src/mcp/mcp-server.js +1473 -0
  99. package/dist/src/mcp/mcp-server.js.map +1 -0
  100. package/dist/src/mcp-server-manager.d.ts +20 -0
  101. package/dist/src/mcp-server-manager.d.ts.map +1 -0
  102. package/dist/src/mcp-server-manager.js +38 -0
  103. package/dist/src/mcp-server-manager.js.map +1 -0
  104. package/dist/src/mcp-server.d.ts +28 -0
  105. package/dist/src/mcp-server.d.ts.map +1 -1
  106. package/dist/src/mcp-server.js +406 -109
  107. package/dist/src/mcp-server.js.map +1 -1
  108. package/dist/src/metrics.d.ts +11 -0
  109. package/dist/src/metrics.d.ts.map +1 -1
  110. package/dist/src/metrics.js +61 -0
  111. package/dist/src/metrics.js.map +1 -1
  112. package/dist/src/oauth-provider.d.ts +5 -0
  113. package/dist/src/oauth-provider.d.ts.map +1 -1
  114. package/dist/src/oauth-provider.js +29 -1
  115. package/dist/src/oauth-provider.js.map +1 -1
  116. package/dist/src/openapi/openapi-parser.d.ts +70 -0
  117. package/dist/src/openapi/openapi-parser.d.ts.map +1 -0
  118. package/dist/src/openapi/openapi-parser.js +458 -0
  119. package/dist/src/openapi/openapi-parser.js.map +1 -0
  120. package/dist/src/profile/profile-loader.d.ts +78 -0
  121. package/dist/src/profile/profile-loader.d.ts.map +1 -0
  122. package/dist/src/profile/profile-loader.js +490 -0
  123. package/dist/src/profile/profile-loader.js.map +1 -0
  124. package/dist/src/profile/profile-registry.d.ts +19 -0
  125. package/dist/src/profile/profile-registry.d.ts.map +1 -0
  126. package/dist/src/profile/profile-registry.js +43 -0
  127. package/dist/src/profile/profile-registry.js.map +1 -0
  128. package/dist/src/profile/profile-resolver.d.ts +41 -0
  129. package/dist/src/profile/profile-resolver.d.ts.map +1 -0
  130. package/dist/src/profile/profile-resolver.js +324 -0
  131. package/dist/src/profile/profile-resolver.js.map +1 -0
  132. package/dist/src/profile/startup-profile.d.ts +17 -0
  133. package/dist/src/profile/startup-profile.d.ts.map +1 -0
  134. package/dist/src/profile/startup-profile.js +30 -0
  135. package/dist/src/profile/startup-profile.js.map +1 -0
  136. package/dist/src/profile/startup-validation.d.ts +11 -0
  137. package/dist/src/profile/startup-validation.d.ts.map +1 -0
  138. package/dist/src/profile/startup-validation.js +21 -0
  139. package/dist/src/profile/startup-validation.js.map +1 -0
  140. package/dist/src/profile-loader.d.ts +1 -0
  141. package/dist/src/profile-loader.d.ts.map +1 -1
  142. package/dist/src/profile-loader.js +14 -3
  143. package/dist/src/profile-loader.js.map +1 -1
  144. package/dist/src/profile-registry.d.ts +18 -0
  145. package/dist/src/profile-registry.d.ts.map +1 -0
  146. package/dist/src/profile-registry.js +26 -0
  147. package/dist/src/profile-registry.js.map +1 -0
  148. package/dist/src/profile-resolver.d.ts +19 -0
  149. package/dist/src/profile-resolver.d.ts.map +1 -0
  150. package/dist/src/profile-resolver.js +167 -0
  151. package/dist/src/profile-resolver.js.map +1 -0
  152. package/dist/src/proxy-executor.d.ts.map +1 -1
  153. package/dist/src/proxy-executor.js +7 -0
  154. package/dist/src/proxy-executor.js.map +1 -1
  155. package/dist/src/startup-profile.d.ts +17 -0
  156. package/dist/src/startup-profile.d.ts.map +1 -0
  157. package/dist/src/startup-profile.js +30 -0
  158. package/dist/src/startup-profile.js.map +1 -0
  159. package/dist/src/startup-validation.d.ts +11 -0
  160. package/dist/src/startup-validation.d.ts.map +1 -0
  161. package/dist/src/startup-validation.js +21 -0
  162. package/dist/src/startup-validation.js.map +1 -0
  163. package/dist/src/testing/dynamic-mock-server.d.ts +24 -0
  164. package/dist/src/testing/dynamic-mock-server.d.ts.map +1 -0
  165. package/dist/src/testing/dynamic-mock-server.js +138 -0
  166. package/dist/src/testing/dynamic-mock-server.js.map +1 -0
  167. package/dist/src/testing/request-assertions.d.ts +5 -0
  168. package/dist/src/testing/request-assertions.d.ts.map +1 -0
  169. package/dist/src/testing/request-assertions.js +165 -0
  170. package/dist/src/testing/request-assertions.js.map +1 -0
  171. package/dist/src/testing/template-utils.d.ts +10 -0
  172. package/dist/src/testing/template-utils.d.ts.map +1 -0
  173. package/dist/src/testing/template-utils.js +72 -0
  174. package/dist/src/testing/template-utils.js.map +1 -0
  175. package/dist/src/testing/test-http-utils.d.ts +1 -1
  176. package/dist/src/testing/test-http-utils.d.ts.map +1 -1
  177. package/dist/src/testing/test-http-utils.js +1 -1
  178. package/dist/src/testing/test-http-utils.js.map +1 -1
  179. package/dist/src/testing/test-loader.d.ts +6 -0
  180. package/dist/src/testing/test-loader.d.ts.map +1 -0
  181. package/dist/src/testing/test-loader.js +212 -0
  182. package/dist/src/testing/test-loader.js.map +1 -0
  183. package/dist/src/testing/test-schema.d.ts +1270 -0
  184. package/dist/src/testing/test-schema.d.ts.map +1 -0
  185. package/dist/src/testing/test-schema.js +76 -0
  186. package/dist/src/testing/test-schema.js.map +1 -0
  187. package/dist/src/tool-filter/compat.d.ts +49 -0
  188. package/dist/src/tool-filter/compat.d.ts.map +1 -0
  189. package/dist/src/tool-filter/compat.js +72 -0
  190. package/dist/src/tool-filter/compat.js.map +1 -0
  191. package/dist/src/tool-filter/config/env-config-parser.d.ts +38 -0
  192. package/dist/src/tool-filter/config/env-config-parser.d.ts.map +1 -0
  193. package/dist/src/tool-filter/config/env-config-parser.js +103 -0
  194. package/dist/src/tool-filter/config/env-config-parser.js.map +1 -0
  195. package/dist/src/tool-filter/config/header-config-parser.d.ts +37 -0
  196. package/dist/src/tool-filter/config/header-config-parser.d.ts.map +1 -0
  197. package/dist/src/tool-filter/config/header-config-parser.js +118 -0
  198. package/dist/src/tool-filter/config/header-config-parser.js.map +1 -0
  199. package/dist/src/tool-filter/errors.d.ts +18 -0
  200. package/dist/src/tool-filter/errors.d.ts.map +1 -0
  201. package/dist/src/tool-filter/errors.js +21 -0
  202. package/dist/src/tool-filter/errors.js.map +1 -0
  203. package/dist/src/tool-filter/filter/filter-engine.d.ts +45 -0
  204. package/dist/src/tool-filter/filter/filter-engine.d.ts.map +1 -0
  205. package/dist/src/tool-filter/filter/filter-engine.js +94 -0
  206. package/dist/src/tool-filter/filter/filter-engine.js.map +1 -0
  207. package/dist/src/tool-filter/filter/filter-rules.d.ts +44 -0
  208. package/dist/src/tool-filter/filter/filter-rules.d.ts.map +1 -0
  209. package/dist/src/tool-filter/filter/filter-rules.js +72 -0
  210. package/dist/src/tool-filter/filter/filter-rules.js.map +1 -0
  211. package/dist/src/tool-filter/filter/global-tool-filter.d.ts +40 -0
  212. package/dist/src/tool-filter/filter/global-tool-filter.d.ts.map +1 -0
  213. package/dist/src/tool-filter/filter/global-tool-filter.js +92 -0
  214. package/dist/src/tool-filter/filter/global-tool-filter.js.map +1 -0
  215. package/dist/src/tool-filter/filter/session-tool-filter.d.ts +29 -0
  216. package/dist/src/tool-filter/filter/session-tool-filter.d.ts.map +1 -0
  217. package/dist/src/tool-filter/filter/session-tool-filter.js +69 -0
  218. package/dist/src/tool-filter/filter/session-tool-filter.js.map +1 -0
  219. package/dist/src/tool-filter/index.d.ts +25 -0
  220. package/dist/src/tool-filter/index.d.ts.map +1 -0
  221. package/dist/src/tool-filter/index.js +30 -0
  222. package/dist/src/tool-filter/index.js.map +1 -0
  223. package/dist/src/tool-filter/integration/tool-filter-service.d.ts +44 -0
  224. package/dist/src/tool-filter/integration/tool-filter-service.d.ts.map +1 -0
  225. package/dist/src/tool-filter/integration/tool-filter-service.js +68 -0
  226. package/dist/src/tool-filter/integration/tool-filter-service.js.map +1 -0
  227. package/dist/src/tool-filter/operation/operation-classifier.d.ts +20 -0
  228. package/dist/src/tool-filter/operation/operation-classifier.d.ts.map +1 -0
  229. package/dist/src/tool-filter/operation/operation-classifier.js +26 -0
  230. package/dist/src/tool-filter/operation/operation-classifier.js.map +1 -0
  231. package/dist/src/tool-filter/operation/operation-detector.d.ts +30 -0
  232. package/dist/src/tool-filter/operation/operation-detector.d.ts.map +1 -0
  233. package/dist/src/tool-filter/operation/operation-detector.js +96 -0
  234. package/dist/src/tool-filter/operation/operation-detector.js.map +1 -0
  235. package/dist/src/tool-filter/operation/operation-resolver.d.ts +22 -0
  236. package/dist/src/tool-filter/operation/operation-resolver.d.ts.map +1 -0
  237. package/dist/src/tool-filter/operation/operation-resolver.js +32 -0
  238. package/dist/src/tool-filter/operation/operation-resolver.js.map +1 -0
  239. package/dist/src/tool-filter/regex/regex-compiler.d.ts +22 -0
  240. package/dist/src/tool-filter/regex/regex-compiler.d.ts.map +1 -0
  241. package/dist/src/tool-filter/regex/regex-compiler.js +56 -0
  242. package/dist/src/tool-filter/regex/regex-compiler.js.map +1 -0
  243. package/dist/src/tool-filter/regex/regex-validator.d.ts +24 -0
  244. package/dist/src/tool-filter/regex/regex-validator.d.ts.map +1 -0
  245. package/dist/src/tool-filter/regex/regex-validator.js +58 -0
  246. package/dist/src/tool-filter/regex/regex-validator.js.map +1 -0
  247. package/dist/src/tool-filter/types.d.ts +92 -0
  248. package/dist/src/tool-filter/types.d.ts.map +1 -0
  249. package/dist/src/tool-filter/types.js +5 -0
  250. package/dist/src/tool-filter/types.js.map +1 -0
  251. package/dist/src/tool-filter/utils.d.ts +11 -0
  252. package/dist/src/tool-filter/utils.d.ts.map +1 -0
  253. package/dist/src/tool-filter/utils.js +13 -0
  254. package/dist/src/tool-filter/utils.js.map +1 -0
  255. package/dist/src/tool-filter.d.ts +65 -0
  256. package/dist/src/tool-filter.d.ts.map +1 -0
  257. package/dist/src/tool-filter.js +471 -0
  258. package/dist/src/tool-filter.js.map +1 -0
  259. package/dist/src/tool-generator.d.ts +1 -0
  260. package/dist/src/tool-generator.d.ts.map +1 -1
  261. package/dist/src/tool-generator.js +15 -6
  262. package/dist/src/tool-generator.js.map +1 -1
  263. package/dist/src/tooling/composite-executor.d.ts +77 -0
  264. package/dist/src/tooling/composite-executor.d.ts.map +1 -0
  265. package/dist/src/tooling/composite-executor.js +198 -0
  266. package/dist/src/tooling/composite-executor.js.map +1 -0
  267. package/dist/src/tooling/dag-executor.d.ts +49 -0
  268. package/dist/src/tooling/dag-executor.d.ts.map +1 -0
  269. package/dist/src/tooling/dag-executor.js +138 -0
  270. package/dist/src/tooling/dag-executor.js.map +1 -0
  271. package/dist/src/tooling/proxy-executor.d.ts +86 -0
  272. package/dist/src/tooling/proxy-executor.d.ts.map +1 -0
  273. package/dist/src/tooling/proxy-executor.js +501 -0
  274. package/dist/src/tooling/proxy-executor.js.map +1 -0
  275. package/dist/src/tooling/tool-generator.d.ts +67 -0
  276. package/dist/src/tooling/tool-generator.d.ts.map +1 -0
  277. package/dist/src/tooling/tool-generator.js +222 -0
  278. package/dist/src/tooling/tool-generator.js.map +1 -0
  279. package/dist/src/transport/http-client-factory.d.ts +65 -0
  280. package/dist/src/transport/http-client-factory.d.ts.map +1 -0
  281. package/dist/src/transport/http-client-factory.js +143 -0
  282. package/dist/src/transport/http-client-factory.js.map +1 -0
  283. package/dist/src/transport/http-transport-config.d.ts +6 -0
  284. package/dist/src/transport/http-transport-config.d.ts.map +1 -0
  285. package/dist/src/transport/http-transport-config.js +63 -0
  286. package/dist/src/transport/http-transport-config.js.map +1 -0
  287. package/dist/src/transport/http-transport.d.ts +329 -0
  288. package/dist/src/transport/http-transport.d.ts.map +1 -0
  289. package/dist/src/transport/http-transport.js +2584 -0
  290. package/dist/src/transport/http-transport.js.map +1 -0
  291. package/dist/src/transport/interceptors.d.ts +119 -0
  292. package/dist/src/transport/interceptors.d.ts.map +1 -0
  293. package/dist/src/transport/interceptors.js +413 -0
  294. package/dist/src/transport/interceptors.js.map +1 -0
  295. package/dist/src/transport/profile-index.d.ts +84 -0
  296. package/dist/src/transport/profile-index.d.ts.map +1 -0
  297. package/dist/src/transport/profile-index.js +405 -0
  298. package/dist/src/transport/profile-index.js.map +1 -0
  299. package/dist/src/types/http-transport.d.ts +26 -0
  300. package/dist/src/types/http-transport.d.ts.map +1 -1
  301. package/dist/src/types/openapi.d.ts +3 -0
  302. package/dist/src/types/openapi.d.ts.map +1 -1
  303. package/dist/src/types/profile.d.ts +16 -1
  304. package/dist/src/types/profile.d.ts.map +1 -1
  305. package/dist/src/validation/argument-normalizer.d.ts +6 -0
  306. package/dist/src/validation/argument-normalizer.d.ts.map +1 -0
  307. package/dist/src/validation/argument-normalizer.js +70 -0
  308. package/dist/src/validation/argument-normalizer.js.map +1 -0
  309. package/dist/src/validation/jsonrpc-validator.d.ts +27 -0
  310. package/dist/src/validation/jsonrpc-validator.d.ts.map +1 -0
  311. package/dist/src/validation/jsonrpc-validator.js +58 -0
  312. package/dist/src/validation/jsonrpc-validator.js.map +1 -0
  313. package/dist/src/validation/schema-validator.d.ts +30 -0
  314. package/dist/src/validation/schema-validator.d.ts.map +1 -0
  315. package/dist/src/validation/schema-validator.js +128 -0
  316. package/dist/src/validation/schema-validator.js.map +1 -0
  317. package/dist/src/validation/validation-utils.d.ts +49 -0
  318. package/dist/src/validation/validation-utils.d.ts.map +1 -0
  319. package/dist/src/validation/validation-utils.js +139 -0
  320. package/dist/src/validation/validation-utils.js.map +1 -0
  321. package/html/profile-index.html +386 -0
  322. package/package.json +10 -3
  323. package/profile-schema.json +77 -3
  324. package/profiles/gitlab/developer-profile-oauth.json +1520 -0
  325. package/profiles/gitlab/developer-profile-oauth.test.json +3432 -0
  326. package/profiles/gitlab/developer-profile.json +1508 -0
  327. package/profiles/gitlab/developer-profile.test.json +3432 -0
  328. package/profiles/gitlab/openapi.yaml +6891 -0
  329. package/profiles/n8n/openapi.yaml +2441 -0
  330. package/profiles/n8n/profile-optimized.json +965 -0
  331. package/profiles/n8n/profile-optimized.test.json +1078 -0
  332. package/profiles/n8n/profile.json +1033 -0
  333. package/profiles/n8n/profile.test.json +983 -0
  334. package/profiles/n8n-nodes/openapi.yaml +24 -0
  335. package/profiles/n8n-nodes/profile-nodes.json +44 -0
  336. package/profiles/n8n-nodes/profile-nodes.test.json +91 -0
  337. package/profiles/semgrep/openapi.yaml +4706 -0
  338. package/profiles/semgrep/profile.json +692 -0
  339. package/profiles/semgrep/profile.test.json +471 -0
  340. package/profiles/youtrack/openapi.json +16976 -0
  341. package/profiles/youtrack/profile.json +608 -0
  342. package/profiles/youtrack/profile.test.json +1926 -0
  343. package/dist/src/testing/fixtures.d.ts +0 -684
  344. package/dist/src/testing/fixtures.d.ts.map +0 -1
  345. package/dist/src/testing/fixtures.js +0 -528
  346. package/dist/src/testing/fixtures.js.map +0 -1
  347. package/dist/src/testing/mock-gitlab-server.d.ts +0 -43
  348. package/dist/src/testing/mock-gitlab-server.d.ts.map +0 -1
  349. package/dist/src/testing/mock-gitlab-server.js +0 -1026
  350. package/dist/src/testing/mock-gitlab-server.js.map +0 -1
  351. package/dist/src/testing/mock-semgrep-server.d.ts +0 -32
  352. package/dist/src/testing/mock-semgrep-server.d.ts.map +0 -1
  353. package/dist/src/testing/mock-semgrep-server.js +0 -213
  354. package/dist/src/testing/mock-semgrep-server.js.map +0 -1
  355. package/dist/src/testing/mock-youtrack-server.d.ts +0 -11
  356. package/dist/src/testing/mock-youtrack-server.d.ts.map +0 -1
  357. package/dist/src/testing/mock-youtrack-server.js +0 -152
  358. package/dist/src/testing/mock-youtrack-server.js.map +0 -1
@@ -0,0 +1,276 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * CLI entry point
4
+ *
5
+ * Why: Reads env vars, initializes server, handles errors gracefully.
6
+ */
7
+ import 'dotenv/config';
8
+ import { MCPServer } from '../mcp/mcp-server.js';
9
+ import { ConsoleLogger, JsonLogger } from './logger.js';
10
+ import { OAUTH_PATHS } from './constants.js';
11
+ import { applyCliEnvOverrides, parseCliArgs } from './cli-config.js';
12
+ import { buildHttpTransportBaseConfig } from '../transport/http-transport-config.js';
13
+ import { ProfileRegistry } from '../profile/profile-registry.js';
14
+ import { MCPServerManager } from '../mcp/mcp-server-manager.js';
15
+ import { getHttpProfileRoutingErrorMessage } from '../profile/startup-validation.js';
16
+ import { listProfiles } from '../profile/profile-resolver.js';
17
+ import { resolveStartupProfile } from '../profile/startup-profile.js';
18
+ /**
19
+ * Fetch OAuth Authorization Server Metadata (RFC 8414)
20
+ * Returns authorization_endpoint and token_endpoint
21
+ */
22
+ export async function fetchOAuthMetadata(issuerUrl) {
23
+ try {
24
+ // Use URL constructor to properly handle trailing slashes
25
+ const metadataUrl = new URL(OAUTH_PATHS.WELL_KNOWN_AUTHORIZATION_SERVER, issuerUrl).toString();
26
+ const response = await fetch(metadataUrl, {
27
+ headers: { 'Accept': 'application/json' },
28
+ signal: AbortSignal.timeout(5000), // 5 second timeout
29
+ });
30
+ if (!response.ok) {
31
+ return null;
32
+ }
33
+ const metadata = await response.json();
34
+ return {
35
+ authorization_endpoint: metadata.authorization_endpoint,
36
+ token_endpoint: metadata.token_endpoint,
37
+ };
38
+ }
39
+ catch (error) {
40
+ return null;
41
+ }
42
+ }
43
+ /**
44
+ * Derive OAuth issuer from API base URL
45
+ * Example: https://www.gitlab.com/api/v4 -> https://www.gitlab.com
46
+ */
47
+ export function deriveIssuerFromBaseUrl(baseUrl) {
48
+ try {
49
+ const url = new URL(baseUrl);
50
+ return url.origin;
51
+ }
52
+ catch {
53
+ return null;
54
+ }
55
+ }
56
+ export function resolveHttpHostPort() {
57
+ const host = process.env.MCP4_HOST || '127.0.0.1';
58
+ const port = parseInt(process.env.MCP4_PORT || '3003', 10);
59
+ if (Number.isNaN(port)) {
60
+ throw new Error(`Invalid MCP4_PORT: ${process.env.MCP4_PORT}`);
61
+ }
62
+ return { host, port };
63
+ }
64
+ export async function main() {
65
+ const cliArgs = parseCliArgs(process.argv.slice(2));
66
+ applyCliEnvOverrides(cliArgs);
67
+ // Create logger early so startup/autodiscovery logs are structured and redacted consistently
68
+ const logFormat = process.env.MCP4_LOG_FORMAT || 'console';
69
+ const logger = logFormat === 'json' ? new JsonLogger() : new ConsoleLogger();
70
+ const profilesDir = process.env.MCP4_PROFILES_DIR;
71
+ if (cliArgs['list-profiles'] === 'true') {
72
+ const profiles = await listProfiles(profilesDir);
73
+ if (profiles.length === 0) {
74
+ console.log('No profiles found.');
75
+ return;
76
+ }
77
+ console.log('Available profiles:');
78
+ for (const profile of profiles) {
79
+ const details = [];
80
+ if (profile.profileName !== profile.profileId) {
81
+ details.push(`name: ${profile.profileName}`);
82
+ }
83
+ if (profile.profileAliases.length > 0) {
84
+ details.push(`aliases: ${profile.profileAliases.join(', ')}`);
85
+ }
86
+ const detailSuffix = details.length > 0 ? ` (${details.join(', ')})` : '';
87
+ console.log(`- ${profile.profileId}${detailSuffix}`);
88
+ }
89
+ return;
90
+ }
91
+ // OAuth Configuration Priority:
92
+ // 1. Explicit env vars (MCP4_OAUTH_AUTHORIZATION_URL, MCP4_OAUTH_TOKEN_URL)
93
+ // 2. Explicit issuer (MCP4_OAUTH_ISSUER)
94
+ // 3. Autodiscovery from MCP4_API_BASE_URL
95
+ const hasOAuthCredentials = process.env.MCP4_OAUTH_CLIENT_ID &&
96
+ process.env.MCP4_OAUTH_CLIENT_SECRET &&
97
+ process.env.MCP4_OAUTH_REDIRECT_URI;
98
+ const hasExplicitOAuthUrls = process.env.MCP4_OAUTH_AUTHORIZATION_URL &&
99
+ process.env.MCP4_OAUTH_TOKEN_URL;
100
+ if (hasOAuthCredentials && !hasExplicitOAuthUrls) {
101
+ // Try OAuth autodiscovery
102
+ let issuer = process.env.MCP4_OAUTH_ISSUER;
103
+ // If no explicit issuer, try to derive from API base URL
104
+ if (!issuer && process.env.MCP4_API_BASE_URL) {
105
+ const derivedIssuer = deriveIssuerFromBaseUrl(process.env.MCP4_API_BASE_URL);
106
+ if (derivedIssuer) {
107
+ issuer = derivedIssuer;
108
+ // Log origin only, not full URL to avoid logging sensitive paths
109
+ const issuerOrigin = new URL(derivedIssuer).origin;
110
+ logger.info('OAuth autodiscovery: derived issuer from MCP4_API_BASE_URL', { issuerOrigin });
111
+ }
112
+ }
113
+ if (issuer) {
114
+ // Try to fetch OAuth metadata
115
+ // Log origin only, not full URL to avoid logging sensitive paths
116
+ const issuerOrigin = new URL(issuer).origin;
117
+ logger.info('OAuth autodiscovery: fetching metadata', { issuerOrigin });
118
+ const metadata = await fetchOAuthMetadata(issuer);
119
+ if (metadata) {
120
+ logger.info('OAuth autodiscovery: successfully discovered OAuth endpoints');
121
+ if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
122
+ process.env.MCP4_OAUTH_AUTHORIZATION_URL = metadata.authorization_endpoint;
123
+ let authorizationEndpointOrigin;
124
+ try {
125
+ authorizationEndpointOrigin = new URL(metadata.authorization_endpoint).origin;
126
+ }
127
+ catch {
128
+ authorizationEndpointOrigin = undefined;
129
+ }
130
+ logger.info('OAuth autodiscovery: set authorization_endpoint', { authorizationEndpointOrigin });
131
+ }
132
+ if (!process.env.MCP4_OAUTH_TOKEN_URL) {
133
+ process.env.MCP4_OAUTH_TOKEN_URL = metadata.token_endpoint;
134
+ let tokenEndpointOrigin;
135
+ try {
136
+ tokenEndpointOrigin = new URL(metadata.token_endpoint).origin;
137
+ }
138
+ catch {
139
+ tokenEndpointOrigin = undefined;
140
+ }
141
+ logger.info('OAuth autodiscovery: set token_endpoint', { tokenEndpointOrigin });
142
+ }
143
+ }
144
+ else {
145
+ // Fallback to standard OAuth paths
146
+ logger.warn('OAuth autodiscovery: metadata fetch failed, using standard OAuth paths', {
147
+ issuerOrigin,
148
+ });
149
+ if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
150
+ process.env.MCP4_OAUTH_AUTHORIZATION_URL = `${issuer}/oauth/authorize`;
151
+ }
152
+ if (!process.env.MCP4_OAUTH_TOKEN_URL) {
153
+ process.env.MCP4_OAUTH_TOKEN_URL = `${issuer}/oauth/token`;
154
+ }
155
+ }
156
+ }
157
+ }
158
+ else if (process.env.MCP4_OAUTH_ISSUER && !hasExplicitOAuthUrls) {
159
+ // Legacy behavior: derive from explicit issuer
160
+ const issuer = process.env.MCP4_OAUTH_ISSUER;
161
+ if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
162
+ process.env.MCP4_OAUTH_AUTHORIZATION_URL = `${issuer}/oauth/authorize`;
163
+ }
164
+ if (!process.env.MCP4_OAUTH_TOKEN_URL) {
165
+ process.env.MCP4_OAUTH_TOKEN_URL = `${issuer}/oauth/token`;
166
+ }
167
+ }
168
+ const specPathOverride = process.env.MCP4_OPENAPI_SPEC_PATH;
169
+ const { specPath, profilePath, profileId, defaultProfile, hasExplicitSpecPath, } = await resolveStartupProfile({
170
+ specPathEnv: specPathOverride,
171
+ profilePath: process.env.MCP4_PROFILE_PATH,
172
+ profileId: process.env.MCP4_PROFILE,
173
+ profilesDir,
174
+ });
175
+ const transport = process.env.MCP4_TRANSPORT || 'stdio';
176
+ const httpProfileRoutingEnabled = process.env.MCP4_HTTP_PROFILE_ROUTING === 'true';
177
+ const hasDefaultProfile = !!defaultProfile;
178
+ const hasSpecPath = !!specPath;
179
+ const routingError = getHttpProfileRoutingErrorMessage({
180
+ transport,
181
+ profileRoutingEnabled: httpProfileRoutingEnabled,
182
+ hasDefaultProfile,
183
+ hasSpecPath,
184
+ });
185
+ if (routingError) {
186
+ logger.error(routingError);
187
+ process.exit(1);
188
+ }
189
+ const requiresSpecPath = transport !== 'http' || !httpProfileRoutingEnabled || hasDefaultProfile;
190
+ if (!specPath && requiresSpecPath) {
191
+ logger.error('MCP4_OPENAPI_SPEC_PATH is required. Provide --openapi-spec-path (or MCP4_OPENAPI_SPEC_PATH), or use --profile with openapi_spec_path in the profile.');
192
+ process.exit(1);
193
+ }
194
+ try {
195
+ if (transport === 'http' && httpProfileRoutingEnabled) {
196
+ const { host, port } = resolveHttpHostPort();
197
+ const baseConfig = buildHttpTransportBaseConfig(host, port);
198
+ const { HttpTransport } = await import('../transport/http-transport.js');
199
+ const httpTransport = new HttpTransport({
200
+ ...baseConfig,
201
+ profileRoutingEnabled: true,
202
+ defaultProfileId: defaultProfile?.profileId,
203
+ }, logger);
204
+ const registry = new ProfileRegistry({
205
+ profilesDir,
206
+ defaultProfile,
207
+ specPathOverride: hasExplicitSpecPath ? specPathOverride : undefined,
208
+ });
209
+ const manager = new MCPServerManager(registry, logger, httpTransport);
210
+ httpTransport.setProfileContextProvider(async (id) => manager.getProfileContext(id));
211
+ httpTransport.setProfileIndexProvider(async () => registry.listProfilesForIndex());
212
+ httpTransport.setMessageHandler(async (message, sessionId, profileId) => {
213
+ if (!profileId) {
214
+ throw new Error('Profile ID is required for HTTP routing.');
215
+ }
216
+ const server = await manager.getServer(profileId);
217
+ return server.handleHttpMessage(message, sessionId, profileId);
218
+ });
219
+ httpTransport.onSessionDestroyed(async (profileId, sessionId) => {
220
+ try {
221
+ const server = await manager.getServer(profileId);
222
+ server.handleSessionDestroyed(profileId, sessionId);
223
+ }
224
+ catch (error) {
225
+ logger.error('Session cleanup failed', error, { profileId, sessionId });
226
+ }
227
+ });
228
+ await httpTransport.start();
229
+ logger.info('MCP server running on HTTP', { host, port });
230
+ const shutdown = async (signal) => {
231
+ logger.info(`Received ${signal}, shutting down gracefully...`);
232
+ try {
233
+ await httpTransport.stop();
234
+ logger.info('Server stopped successfully');
235
+ process.exit(0);
236
+ }
237
+ catch (error) {
238
+ logger.error('Error during shutdown', error);
239
+ process.exit(1);
240
+ }
241
+ };
242
+ process.on('SIGTERM', () => shutdown('SIGTERM'));
243
+ process.on('SIGINT', () => shutdown('SIGINT'));
244
+ return;
245
+ }
246
+ const server = new MCPServer(logger);
247
+ await server.initialize(specPath, profilePath);
248
+ if (transport === 'http') {
249
+ const { host, port } = resolveHttpHostPort();
250
+ await server.runHttp(host, port);
251
+ }
252
+ else {
253
+ await server.runStdio();
254
+ }
255
+ // Graceful shutdown handlers
256
+ const shutdown = async (signal) => {
257
+ logger.info(`Received ${signal}, shutting down gracefully...`);
258
+ try {
259
+ await server.stop();
260
+ logger.info('Server stopped successfully');
261
+ process.exit(0);
262
+ }
263
+ catch (error) {
264
+ logger.error('Error during shutdown', error);
265
+ process.exit(1);
266
+ }
267
+ };
268
+ process.on('SIGTERM', () => shutdown('SIGTERM'));
269
+ process.on('SIGINT', () => shutdown('SIGINT'));
270
+ }
271
+ catch (error) {
272
+ logger.error('Fatal error', error);
273
+ process.exit(1);
274
+ }
275
+ }
276
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/index.ts"],"names":[],"mappings":";AAEA;;;;GAIG;AAEH,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACrE,OAAO,EAAE,4BAA4B,EAAE,MAAM,uCAAuC,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,iCAAiC,EAAE,MAAM,kCAAkC,CAAC;AACrF,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AAEtE;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,SAAiB;IACxD,IAAI,CAAC;QACH,0DAA0D;QAC1D,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,+BAA+B,EAAE,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC/F,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,WAAW,EAAE;YACxC,OAAO,EAAE,EAAE,QAAQ,EAAE,kBAAkB,EAAE;YACzC,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,mBAAmB;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,QAAQ,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAS,CAAC;QAC9C,OAAO;YACL,sBAAsB,EAAE,QAAQ,CAAC,sBAAsB;YACvD,cAAc,EAAE,QAAQ,CAAC,cAAc;SACxC,CAAC;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,uBAAuB,CAAC,OAAe;IACrD,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC;QAC7B,OAAO,GAAG,CAAC,MAAM,CAAC;IACpB,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB;IACjC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,WAAW,CAAC;IAClD,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,MAAM,EAAE,EAAE,CAAC,CAAC;IAE3D,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,sBAAsB,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACxB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,IAAI;IACxB,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,oBAAoB,CAAC,OAAO,CAAC,CAAC;IAE9B,6FAA6F;IAC7F,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,SAAS,CAAC;IAC3D,MAAM,MAAM,GAAG,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,aAAa,EAAE,CAAC;IAE7E,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;IAClD,IAAI,OAAO,CAAC,eAAe,CAAC,KAAK,MAAM,EAAE,CAAC;QACxC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,WAAW,CAAC,CAAC;QACjD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;YAClC,OAAO;QACT,CAAC;QACD,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;QACnC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,OAAO,GAAa,EAAE,CAAC;YAC7B,IAAI,OAAO,CAAC,WAAW,KAAK,OAAO,CAAC,SAAS,EAAE,CAAC;gBAC9C,OAAO,CAAC,IAAI,CAAC,SAAS,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;YAC/C,CAAC;YACD,IAAI,OAAO,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtC,OAAO,CAAC,IAAI,CAAC,YAAY,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChE,CAAC;YACD,MAAM,YAAY,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YAC1E,OAAO,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,SAAS,GAAG,YAAY,EAAE,CAAC,CAAC;QACvD,CAAC;QACD,OAAO;IACT,CAAC;IAED,gCAAgC;IAChC,4EAA4E;IAC5E,yCAAyC;IACzC,0CAA0C;IAE1C,MAAM,mBAAmB,GACvB,OAAO,CAAC,GAAG,CAAC,oBAAoB;QAChC,OAAO,CAAC,GAAG,CAAC,wBAAwB;QACpC,OAAO,CAAC,GAAG,CAAC,uBAAuB,CAAC;IAEtC,MAAM,oBAAoB,GACxB,OAAO,CAAC,GAAG,CAAC,4BAA4B;QACxC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC;IAEnC,IAAI,mBAAmB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACjD,0BAA0B;QAC1B,IAAI,MAAM,GAAuB,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QAE/D,yDAAyD;QACzD,IAAI,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC;YAC7C,MAAM,aAAa,GAAG,uBAAuB,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YAC7E,IAAI,aAAa,EAAE,CAAC;gBAClB,MAAM,GAAG,aAAa,CAAC;gBACvB,iEAAiE;gBACjE,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC;gBACnD,MAAM,CAAC,IAAI,CAAC,4DAA4D,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;YAC9F,CAAC;QACH,CAAC;QAED,IAAI,MAAM,EAAE,CAAC;YACX,8BAA8B;YAC9B,iEAAiE;YACjE,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC;YAC5C,MAAM,CAAC,IAAI,CAAC,wCAAwC,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;YACxE,MAAM,QAAQ,GAAG,MAAM,kBAAkB,CAAC,MAAM,CAAC,CAAC;YAElD,IAAI,QAAQ,EAAE,CAAC;gBACb,MAAM,CAAC,IAAI,CAAC,8DAA8D,CAAC,CAAC;gBAC5E,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,4BAA4B,EAAE,CAAC;oBAC9C,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,QAAQ,CAAC,sBAAsB,CAAC;oBAC3E,IAAI,2BAA+C,CAAC;oBACpD,IAAI,CAAC;wBACH,2BAA2B,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC;oBAChF,CAAC;oBAAC,MAAM,CAAC;wBACP,2BAA2B,GAAG,SAAS,CAAC;oBAC1C,CAAC;oBACD,MAAM,CAAC,IAAI,CAAC,iDAAiD,EAAE,EAAE,2BAA2B,EAAE,CAAC,CAAC;gBAClG,CAAC;gBACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,CAAC;oBACtC,OAAO,CAAC,GAAG,CAAC,oBAAoB,GAAG,QAAQ,CAAC,cAAc,CAAC;oBAC3D,IAAI,mBAAuC,CAAC;oBAC5C,IAAI,CAAC;wBACH,mBAAmB,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC;oBAChE,CAAC;oBAAC,MAAM,CAAC;wBACP,mBAAmB,GAAG,SAAS,CAAC;oBAClC,CAAC;oBACD,MAAM,CAAC,IAAI,CAAC,yCAAyC,EAAE,EAAE,mBAAmB,EAAE,CAAC,CAAC;gBAClF,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,mCAAmC;gBACnC,MAAM,CAAC,IAAI,CAAC,wEAAwE,EAAE;oBACpF,YAAY;iBACb,CAAC,CAAC;gBACH,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,4BAA4B,EAAE,CAAC;oBAC9C,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,GAAG,MAAM,kBAAkB,CAAC;gBACzE,CAAC;gBACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,CAAC;oBACtC,OAAO,CAAC,GAAG,CAAC,oBAAoB,GAAG,GAAG,MAAM,cAAc,CAAC;gBAC7D,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;SAAM,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAClE,+CAA+C;QAC/C,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QAC7C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,4BAA4B,EAAE,CAAC;YAC9C,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,GAAG,MAAM,kBAAkB,CAAC;QACzE,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,CAAC;YACtC,OAAO,CAAC,GAAG,CAAC,oBAAoB,GAAG,GAAG,MAAM,cAAc,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC;IAC5D,MAAM,EACJ,QAAQ,EACR,WAAW,EACX,SAAS,EACT,cAAc,EACd,mBAAmB,GACpB,GAAG,MAAM,qBAAqB,CAAC;QAC9B,WAAW,EAAE,gBAAgB;QAC7B,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;QAC1C,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;QACnC,WAAW;KACZ,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,OAAO,CAAC;IACxD,MAAM,yBAAyB,GAAG,OAAO,CAAC,GAAG,CAAC,yBAAyB,KAAK,MAAM,CAAC;IACnF,MAAM,iBAAiB,GAAG,CAAC,CAAC,cAAc,CAAC;IAC3C,MAAM,WAAW,GAAG,CAAC,CAAC,QAAQ,CAAC;IAE/B,MAAM,YAAY,GAAG,iCAAiC,CAAC;QACrD,SAAS;QACT,qBAAqB,EAAE,yBAAyB;QAChD,iBAAiB;QACjB,WAAW;KACZ,CAAC,CAAC;IACH,IAAI,YAAY,EAAE,CAAC;QACjB,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAC3B,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,gBAAgB,GAAG,SAAS,KAAK,MAAM,IAAI,CAAC,yBAAyB,IAAI,iBAAiB,CAAC;IACjG,IAAI,CAAC,QAAQ,IAAI,gBAAgB,EAAE,CAAC;QAClC,MAAM,CAAC,KAAK,CAAC,sJAAsJ,CAAC,CAAC;QACrK,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,CAAC;QACH,IAAI,SAAS,KAAK,MAAM,IAAI,yBAAyB,EAAE,CAAC;YACtD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,mBAAmB,EAAE,CAAC;YAE7C,MAAM,UAAU,GAAG,4BAA4B,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC5D,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,gCAAgC,CAAC,CAAC;YACzE,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC;gBACtC,GAAG,UAAU;gBACb,qBAAqB,EAAE,IAAI;gBAC3B,gBAAgB,EAAE,cAAc,EAAE,SAAS;aAC5C,EAAE,MAAM,CAAC,CAAC;YAEX,MAAM,QAAQ,GAAG,IAAI,eAAe,CAAC;gBACnC,WAAW;gBACX,cAAc;gBACd,gBAAgB,EAAE,mBAAmB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS;aACrE,CAAC,CAAC;YACH,MAAM,OAAO,GAAG,IAAI,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC;YAEtE,aAAa,CAAC,yBAAyB,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC;YACrF,aAAa,CAAC,uBAAuB,CAAC,KAAK,IAAI,EAAE,CAAC,QAAQ,CAAC,oBAAoB,EAAE,CAAC,CAAC;YAEnF,aAAa,CAAC,iBAAiB,CAAC,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE;gBACtE,IAAI,CAAC,SAAS,EAAE,CAAC;oBACf,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;gBAC9D,CAAC;gBACD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;gBAClD,OAAO,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;YACjE,CAAC,CAAC,CAAC;YAEH,aAAa,CAAC,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE;gBAC9D,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;oBAClD,MAAM,CAAC,sBAAsB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;gBACtD,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,KAAc,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;gBACnF,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,MAAM,aAAa,CAAC,KAAK,EAAE,CAAC;YAC5B,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YAE1D,MAAM,QAAQ,GAAG,KAAK,EAAE,MAAc,EAAE,EAAE;gBACxC,MAAM,CAAC,IAAI,CAAC,YAAY,MAAM,+BAA+B,CAAC,CAAC;gBAC/D,IAAI,CAAC;oBACH,MAAM,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC3B,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;oBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAc,CAAC,CAAC;oBACtD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,CAAC;YACH,CAAC,CAAC;YAEF,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;YACjD,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC/C,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,MAAM,CAAC,UAAU,CAAC,QAAS,EAAE,WAAW,CAAC,CAAC;QAEhD,IAAI,SAAS,KAAK,MAAM,EAAE,CAAC;YACzB,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,mBAAmB,EAAE,CAAC;YAE7C,MAAM,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;QAC1B,CAAC;QAED,6BAA6B;QAC7B,MAAM,QAAQ,GAAG,KAAK,EAAE,MAAc,EAAE,EAAE;YACxC,MAAM,CAAC,IAAI,CAAC,YAAY,MAAM,+BAA+B,CAAC,CAAC;YAC/D,IAAI,CAAC;gBACH,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;gBACpB,MAAM,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;gBAC3C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,KAAK,CAAC,uBAAuB,EAAE,KAAc,CAAC,CAAC;gBACtD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC;QACH,CAAC,CAAC;QAEF,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;QACjD,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEjD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,CAAC,KAAK,CAAC,aAAa,EAAE,KAAc,CAAC,CAAC;QAC5C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Library exports for programmatic usage
3
+ */
4
+ export { MCPServer } from '../mcp/mcp-server.js';
5
+ export { HttpTransport } from '../transport/http-transport.js';
6
+ export { ConsoleLogger, JsonLogger } from './logger.js';
7
+ export type { Profile, ToolDefinition, InterceptorConfig } from '../types/profile.js';
8
+ //# sourceMappingURL=lib.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../../../src/core/lib.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACxD,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Library exports for programmatic usage
3
+ */
4
+ export { MCPServer } from '../mcp/mcp-server.js';
5
+ export { HttpTransport } from '../transport/http-transport.js';
6
+ export { ConsoleLogger, JsonLogger } from './logger.js';
7
+ //# sourceMappingURL=lib.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lib.js","sourceRoot":"","sources":["../../../src/core/lib.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Logger interfaces and implementations
3
+ *
4
+ * Why: Replaces console.error with structured, level-based logging.
5
+ * Enables production-ready logging with context and proper error handling.
6
+ *
7
+ * Security: Profile-aware token redaction prevents sensitive data leakage.
8
+ */
9
+ import type { AuthInterceptor } from '../types/profile.js';
10
+ /**
11
+ * Sanitize log message to prevent log injection
12
+ * Strips ANSI codes and escapes control characters
13
+ */
14
+ export declare function sanitizeLogMessage(message: string): string;
15
+ export declare enum LogLevel {
16
+ DEBUG = 0,
17
+ INFO = 1,
18
+ WARN = 2,
19
+ ERROR = 3,
20
+ SILENT = 4
21
+ }
22
+ export interface Logger {
23
+ debug(message: string, context?: Record<string, unknown>): void;
24
+ info(message: string, context?: Record<string, unknown>): void;
25
+ warn(message: string, context?: Record<string, unknown>): void;
26
+ error(message: string, error?: Error, context?: Record<string, unknown>): void;
27
+ }
28
+ /**
29
+ * Default logger - writes to stderr, respects MCP4_LOG_LEVEL env var
30
+ *
31
+ * Security: Redacts auth tokens based on profile configuration
32
+ */
33
+ export declare class ConsoleLogger implements Logger {
34
+ private level;
35
+ private authConfig?;
36
+ constructor(level?: LogLevel, authConfig?: AuthInterceptor);
37
+ debug(message: string, context?: Record<string, unknown>): void;
38
+ info(message: string, context?: Record<string, unknown>): void;
39
+ warn(message: string, context?: Record<string, unknown>): void;
40
+ error(message: string, error?: Error, context?: Record<string, unknown>): void;
41
+ private write;
42
+ }
43
+ /**
44
+ * Structured JSON logger for production
45
+ *
46
+ * Why: Machine-readable logs for log aggregation systems (ELK, Splunk, etc.)
47
+ * Security: Redacts auth tokens based on profile configuration
48
+ */
49
+ export declare class JsonLogger implements Logger {
50
+ private level;
51
+ private authConfig?;
52
+ constructor(level?: LogLevel, authConfig?: AuthInterceptor);
53
+ debug(message: string, context?: Record<string, unknown>): void;
54
+ info(message: string, context?: Record<string, unknown>): void;
55
+ warn(message: string, context?: Record<string, unknown>): void;
56
+ error(message: string, error?: Error, context?: Record<string, unknown>): void;
57
+ private write;
58
+ }
59
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/core/logger.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AA8C3D;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAuB1D;AAwCD,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;IACT,MAAM,IAAI;CACX;AAED,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAChE,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CAChF;AAED;;;;GAIG;AACH,qBAAa,aAAc,YAAW,MAAM;IAC1C,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,UAAU,CAAC,CAAkB;gBAEzB,KAAK,CAAC,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,eAAe;IAK1D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAW9E,OAAO,CAAC,KAAK;CAOd;AAED;;;;;GAKG;AACH,qBAAa,UAAW,YAAW,MAAM;IACvC,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,UAAU,CAAC,CAAkB;gBAEzB,KAAK,CAAC,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,eAAe;IAK1D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAU9E,OAAO,CAAC,KAAK;CAUd"}
@@ -0,0 +1,197 @@
1
+ /**
2
+ * Logger interfaces and implementations
3
+ *
4
+ * Why: Replaces console.error with structured, level-based logging.
5
+ * Enables production-ready logging with context and proper error handling.
6
+ *
7
+ * Security: Profile-aware token redaction prevents sensitive data leakage.
8
+ */
9
+ import { stripVTControlCharacters } from 'node:util';
10
+ import { redactHeader, redactQueryParam, redactParam } from '../validation/validation-utils.js';
11
+ const WELL_KNOWN_SECRET_KEYS = new Set([
12
+ 'access_token',
13
+ 'refresh_token',
14
+ 'id_token',
15
+ 'client_secret',
16
+ 'client_assertion',
17
+ 'code',
18
+ 'code_verifier',
19
+ ]);
20
+ function deepRedactWellKnownSecrets(value, depth = 0, seen) {
21
+ if (depth > 20)
22
+ return value;
23
+ if (value === null || typeof value !== 'object')
24
+ return value;
25
+ if (!seen)
26
+ seen = new WeakSet();
27
+ if (seen.has(value))
28
+ return value;
29
+ seen.add(value);
30
+ if (Array.isArray(value)) {
31
+ return value.map(item => deepRedactWellKnownSecrets(item, depth + 1, seen));
32
+ }
33
+ const record = value;
34
+ const out = {};
35
+ for (const [key, val] of Object.entries(record)) {
36
+ if (WELL_KNOWN_SECRET_KEYS.has(key)) {
37
+ out[key] = '[REDACTED]';
38
+ continue;
39
+ }
40
+ out[key] = deepRedactWellKnownSecrets(val, depth + 1, seen);
41
+ }
42
+ return out;
43
+ }
44
+ function resolveLogLevel(explicitLevel) {
45
+ if (explicitLevel !== undefined)
46
+ return explicitLevel;
47
+ const envLevel = process.env.MCP4_LOG_LEVEL?.toUpperCase();
48
+ return envLevel && envLevel in LogLevel
49
+ ? LogLevel[envLevel]
50
+ : LogLevel.INFO;
51
+ }
52
+ /**
53
+ * Sanitize log message to prevent log injection
54
+ * Strips ANSI codes and escapes control characters
55
+ */
56
+ export function sanitizeLogMessage(message) {
57
+ // 1. Strip ANSI escape codes
58
+ let safe = stripVTControlCharacters(message);
59
+ // 2. Escape control characters (0x00-0x1F, 0x7F)
60
+ // We use a replacement function to handle various control characters
61
+ safe = safe.replace(/[\x00-\x1F\x7F]/g, (char) => {
62
+ switch (char) {
63
+ case '\n': return '\\n';
64
+ case '\r': return '\\r';
65
+ case '\t': return '\\t';
66
+ case '\b': return '\\b';
67
+ case '\f': return '\\f';
68
+ case '\v': return '\\v';
69
+ case '\0': return '\\0';
70
+ default:
71
+ // Hex escape for other control chars (e.g. \x07)
72
+ const hex = char.charCodeAt(0).toString(16).padStart(2, '0');
73
+ return `\\x${hex}`;
74
+ }
75
+ });
76
+ return safe;
77
+ }
78
+ function redactSensitiveContext(data, authConfig) {
79
+ const redacted = deepRedactWellKnownSecrets(data);
80
+ if (!authConfig)
81
+ return redacted;
82
+ switch (authConfig.type) {
83
+ case 'bearer':
84
+ redacted.headers = redactHeader(redacted.headers, 'authorization');
85
+ break;
86
+ case 'custom-header':
87
+ if (authConfig.header_name) {
88
+ redacted.headers = redactHeader(redacted.headers, authConfig.header_name.toLowerCase());
89
+ }
90
+ break;
91
+ case 'query':
92
+ if (authConfig.query_param) {
93
+ redacted.url = redactQueryParam(redacted.url, authConfig.query_param);
94
+ redacted.params = redactParam(redacted.params, authConfig.query_param);
95
+ }
96
+ break;
97
+ }
98
+ return redacted;
99
+ }
100
+ export var LogLevel;
101
+ (function (LogLevel) {
102
+ LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG";
103
+ LogLevel[LogLevel["INFO"] = 1] = "INFO";
104
+ LogLevel[LogLevel["WARN"] = 2] = "WARN";
105
+ LogLevel[LogLevel["ERROR"] = 3] = "ERROR";
106
+ LogLevel[LogLevel["SILENT"] = 4] = "SILENT";
107
+ })(LogLevel || (LogLevel = {}));
108
+ /**
109
+ * Default logger - writes to stderr, respects MCP4_LOG_LEVEL env var
110
+ *
111
+ * Security: Redacts auth tokens based on profile configuration
112
+ */
113
+ export class ConsoleLogger {
114
+ constructor(level, authConfig) {
115
+ this.level = resolveLogLevel(level);
116
+ this.authConfig = authConfig;
117
+ }
118
+ debug(message, context) {
119
+ if (this.level <= LogLevel.DEBUG) {
120
+ this.write('DEBUG', message, context);
121
+ }
122
+ }
123
+ info(message, context) {
124
+ if (this.level <= LogLevel.INFO) {
125
+ this.write('INFO', message, context);
126
+ }
127
+ }
128
+ warn(message, context) {
129
+ if (this.level <= LogLevel.WARN) {
130
+ this.write('WARN', message, context);
131
+ }
132
+ }
133
+ error(message, error, context) {
134
+ if (this.level <= LogLevel.ERROR) {
135
+ const errorContext = error ? {
136
+ error: error.message,
137
+ stack: error.stack,
138
+ ...context,
139
+ } : context;
140
+ this.write('ERROR', message, errorContext);
141
+ }
142
+ }
143
+ write(level, message, context) {
144
+ const timestamp = new Date().toISOString();
145
+ const redacted = context ? redactSensitiveContext(context, this.authConfig) : undefined;
146
+ const ctx = redacted ? ` ${JSON.stringify(redacted)}` : '';
147
+ const safeMessage = sanitizeLogMessage(message);
148
+ console.error(`[${timestamp}] ${level}: ${safeMessage}${ctx}`);
149
+ }
150
+ }
151
+ /**
152
+ * Structured JSON logger for production
153
+ *
154
+ * Why: Machine-readable logs for log aggregation systems (ELK, Splunk, etc.)
155
+ * Security: Redacts auth tokens based on profile configuration
156
+ */
157
+ export class JsonLogger {
158
+ constructor(level, authConfig) {
159
+ this.level = resolveLogLevel(level);
160
+ this.authConfig = authConfig;
161
+ }
162
+ debug(message, context) {
163
+ if (this.level <= LogLevel.DEBUG) {
164
+ this.write('debug', message, context);
165
+ }
166
+ }
167
+ info(message, context) {
168
+ if (this.level <= LogLevel.INFO) {
169
+ this.write('info', message, context);
170
+ }
171
+ }
172
+ warn(message, context) {
173
+ if (this.level <= LogLevel.WARN) {
174
+ this.write('warn', message, context);
175
+ }
176
+ }
177
+ error(message, error, context) {
178
+ if (this.level <= LogLevel.ERROR) {
179
+ this.write('error', message, {
180
+ error: error?.message,
181
+ stack: error?.stack,
182
+ ...context,
183
+ });
184
+ }
185
+ }
186
+ write(level, message, context) {
187
+ const redacted = context ? redactSensitiveContext(context, this.authConfig) : undefined;
188
+ const log = {
189
+ timestamp: new Date().toISOString(),
190
+ level,
191
+ message,
192
+ ...redacted,
193
+ };
194
+ console.error(JSON.stringify(log));
195
+ }
196
+ }
197
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/core/logger.ts"],"names":[],"mappings":"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"}