@decaf-ts/mcp-server 0.0.4 → 0.2.0

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 (210) hide show
  1. package/README.md +18 -2
  2. package/dist/mcp-server.cjs +1986 -340
  3. package/dist/mcp-server.esm.cjs +1960 -337
  4. package/lib/McpWrapper.cjs +9 -9
  5. package/lib/McpWrapper.d.ts +1 -1
  6. package/lib/bin/validate-modules.cjs +24 -0
  7. package/lib/bin/validate-modules.d.ts +2 -0
  8. package/lib/constants.cjs +22 -2
  9. package/lib/constants.d.ts +16 -0
  10. package/lib/esm/McpWrapper.d.ts +1 -1
  11. package/lib/esm/McpWrapper.js +9 -9
  12. package/lib/esm/bin/validate-modules.d.ts +2 -0
  13. package/lib/esm/bin/validate-modules.js +22 -0
  14. package/lib/esm/constants.d.ts +16 -0
  15. package/lib/esm/constants.js +21 -1
  16. package/lib/esm/mcp/aggregateModules.d.ts +26 -0
  17. package/lib/esm/mcp/aggregateModules.js +185 -0
  18. package/lib/esm/mcp/code.d.ts +23 -0
  19. package/lib/esm/mcp/code.js +70 -0
  20. package/lib/esm/mcp/decorator-tools.js +237 -0
  21. package/lib/esm/mcp/fastmcp-wiring.d.ts +14 -0
  22. package/lib/esm/mcp/fastmcp-wiring.js +56 -0
  23. package/lib/esm/mcp/index.d.ts +7 -1
  24. package/lib/esm/mcp/index.js +26 -2
  25. package/lib/esm/mcp/mcp-module.d.ts +11 -0
  26. package/lib/esm/mcp/mcp-module.js +31 -0
  27. package/lib/esm/mcp/moduleRegistry.d.ts +12 -0
  28. package/lib/esm/mcp/moduleRegistry.js +46 -0
  29. package/lib/esm/mcp/prompts/index.d.ts +4 -0
  30. package/lib/esm/mcp/prompts/index.js +7 -0
  31. package/lib/esm/mcp/prompts/prompts.d.ts +22 -0
  32. package/lib/esm/mcp/prompts/prompts.js +197 -0
  33. package/lib/esm/mcp/resources/index.d.ts +1 -0
  34. package/lib/esm/mcp/resources/index.js +2 -0
  35. package/lib/esm/mcp/resources/resources.d.ts +2 -0
  36. package/lib/esm/mcp/resources/resources.js +69 -0
  37. package/lib/esm/mcp/schemas.d.ts +53 -0
  38. package/lib/esm/mcp/schemas.js +97 -0
  39. package/lib/esm/mcp/templates/codex-templates.d.ts +3 -0
  40. package/lib/esm/mcp/templates/codex-templates.js +33 -0
  41. package/lib/esm/mcp/templates/index.d.ts +71 -0
  42. package/lib/esm/mcp/templates/index.js +66 -0
  43. package/lib/esm/mcp/templates/resource-templates.d.ts +3 -0
  44. package/lib/esm/mcp/templates/resource-templates.js +60 -0
  45. package/lib/esm/mcp/templates/workspace-templates.d.ts +3 -0
  46. package/lib/esm/mcp/templates/workspace-templates.js +66 -0
  47. package/lib/esm/mcp/tools/codex-tools.d.ts +5 -0
  48. package/lib/esm/mcp/tools/codex-tools.js +244 -0
  49. package/lib/esm/mcp/tools/generateMcpModule.d.ts +9 -0
  50. package/lib/esm/mcp/tools/generateMcpModule.js +133 -0
  51. package/lib/esm/mcp/tools/index.d.ts +321 -0
  52. package/lib/esm/mcp/tools/index.js +29 -0
  53. package/lib/esm/mcp/tools/tools.d.ts +10 -0
  54. package/lib/esm/mcp/tools/tools.js +273 -0
  55. package/lib/esm/mcp/types.d.ts +66 -0
  56. package/lib/esm/mcp/types.js +2 -0
  57. package/lib/esm/mcp/utils.d.ts +4 -0
  58. package/lib/esm/mcp/utils.js +46 -0
  59. package/lib/esm/mcp/validation/index.d.ts +13 -0
  60. package/lib/esm/mcp/validation/index.js +116 -0
  61. package/lib/esm/mcp/validation/scaffoldModule.d.ts +9 -0
  62. package/lib/esm/mcp/validation/scaffoldModule.js +88 -0
  63. package/lib/esm/mcp/workspace.d.ts +9 -0
  64. package/lib/esm/mcp/workspace.js +73 -0
  65. package/lib/esm/metadata.d.ts +1 -1
  66. package/lib/esm/metadata.js +1 -1
  67. package/lib/esm/modules/_template/index.d.ts +32 -0
  68. package/lib/esm/modules/_template/index.js +16 -0
  69. package/lib/esm/modules/_template/prompts/index.d.ts +6 -0
  70. package/lib/esm/modules/_template/prompts/index.js +9 -0
  71. package/lib/esm/modules/_template/resources/index.d.ts +6 -0
  72. package/lib/esm/modules/_template/resources/index.js +9 -0
  73. package/lib/esm/modules/_template/templates/index.d.ts +7 -0
  74. package/lib/esm/modules/_template/templates/index.js +10 -0
  75. package/lib/esm/modules/_template/tools/index.d.ts +6 -0
  76. package/lib/esm/modules/_template/tools/index.js +15 -0
  77. package/lib/esm/modules/decoration/index.d.ts +46 -0
  78. package/lib/esm/modules/decoration/index.js +10 -2
  79. package/lib/esm/modules/decoration/prompts/index.d.ts +1 -0
  80. package/lib/esm/modules/decoration/prompts/index.js +2 -0
  81. package/lib/esm/modules/decoration/resources/index.d.ts +7 -0
  82. package/lib/esm/modules/decoration/resources/index.js +10 -0
  83. package/lib/esm/modules/decoration/templates/index.d.ts +6 -0
  84. package/lib/esm/modules/decoration/templates/index.js +9 -0
  85. package/lib/esm/modules/decoration/tools/index.d.ts +26 -0
  86. package/lib/esm/modules/decoration/tools/index.js +7 -0
  87. package/lib/esm/modules/index.d.ts +2 -0
  88. package/lib/esm/modules/index.js +10 -0
  89. package/lib/esm/modules/mcp/decoration-assist.d.ts +3 -38
  90. package/lib/esm/modules/mcp/decoration-assist.js +5 -352
  91. package/lib/esm/modules/mcp/index.d.ts +6 -2
  92. package/lib/esm/modules/mcp/index.js +16 -3
  93. package/lib/esm/modules/mcp/prompts/index.d.ts +2 -0
  94. package/lib/esm/modules/mcp/prompts/index.js +9 -0
  95. package/lib/esm/modules/mcp/resources/index.d.ts +2 -0
  96. package/lib/esm/modules/mcp/resources/index.js +24 -0
  97. package/lib/esm/modules/mcp/templates/index.d.ts +2 -0
  98. package/lib/esm/modules/mcp/templates/index.js +28 -0
  99. package/lib/esm/modules/mcp/tools/index.d.ts +6 -0
  100. package/lib/esm/modules/mcp/tools/index.js +15 -0
  101. package/lib/esm/types.d.ts +41 -1
  102. package/lib/esm/types.js +1 -1
  103. package/lib/esm/utils/modulePaths.d.ts +6 -0
  104. package/lib/esm/utils/modulePaths.js +33 -0
  105. package/lib/esm/utils/moduleValidator.d.ts +14 -0
  106. package/lib/esm/utils/moduleValidator.js +176 -0
  107. package/lib/esm/utils.d.ts +1 -0
  108. package/lib/esm/utils.js +2 -1
  109. package/lib/mcp/aggregateModules.cjs +225 -0
  110. package/lib/mcp/aggregateModules.d.ts +26 -0
  111. package/lib/mcp/code.cjs +81 -0
  112. package/lib/mcp/code.d.ts +23 -0
  113. package/lib/mcp/decorator-tools.cjs +243 -0
  114. package/lib/mcp/fastmcp-wiring.cjs +59 -0
  115. package/lib/mcp/fastmcp-wiring.d.ts +14 -0
  116. package/lib/mcp/index.cjs +47 -12
  117. package/lib/mcp/index.d.ts +7 -1
  118. package/lib/mcp/mcp-module.cjs +53 -0
  119. package/lib/mcp/mcp-module.d.ts +11 -0
  120. package/lib/mcp/moduleRegistry.cjs +50 -0
  121. package/lib/mcp/moduleRegistry.d.ts +12 -0
  122. package/lib/mcp/prompts/index.cjs +25 -0
  123. package/lib/mcp/prompts/index.d.ts +4 -0
  124. package/lib/mcp/prompts/prompts.cjs +211 -0
  125. package/lib/mcp/prompts/prompts.d.ts +22 -0
  126. package/lib/mcp/resources/index.cjs +18 -0
  127. package/lib/mcp/resources/index.d.ts +1 -0
  128. package/lib/mcp/resources/resources.cjs +72 -0
  129. package/lib/mcp/resources/resources.d.ts +2 -0
  130. package/lib/mcp/schemas.cjs +100 -0
  131. package/lib/mcp/schemas.d.ts +53 -0
  132. package/lib/mcp/templates/codex-templates.cjs +40 -0
  133. package/lib/mcp/templates/codex-templates.d.ts +3 -0
  134. package/lib/mcp/templates/index.cjs +76 -0
  135. package/lib/mcp/templates/index.d.ts +71 -0
  136. package/lib/mcp/templates/resource-templates.cjs +67 -0
  137. package/lib/mcp/templates/resource-templates.d.ts +3 -0
  138. package/lib/mcp/templates/workspace-templates.cjs +70 -0
  139. package/lib/mcp/templates/workspace-templates.d.ts +3 -0
  140. package/lib/mcp/tools/codex-tools.cjs +250 -0
  141. package/lib/mcp/tools/codex-tools.d.ts +5 -0
  142. package/lib/mcp/tools/generateMcpModule.cjs +139 -0
  143. package/lib/mcp/tools/generateMcpModule.d.ts +9 -0
  144. package/lib/mcp/tools/index.cjs +46 -0
  145. package/lib/mcp/tools/index.d.ts +321 -0
  146. package/lib/mcp/tools/tools.cjs +282 -0
  147. package/lib/mcp/tools/tools.d.ts +10 -0
  148. package/lib/mcp/types.cjs +3 -0
  149. package/lib/mcp/types.d.ts +66 -0
  150. package/lib/mcp/utils.cjs +54 -0
  151. package/lib/mcp/utils.d.ts +4 -0
  152. package/lib/mcp/validation/index.cjs +123 -0
  153. package/lib/mcp/validation/index.d.ts +13 -0
  154. package/lib/mcp/validation/scaffoldModule.cjs +94 -0
  155. package/lib/mcp/validation/scaffoldModule.d.ts +9 -0
  156. package/lib/mcp/workspace.cjs +119 -0
  157. package/lib/mcp/workspace.d.ts +9 -0
  158. package/lib/metadata.cjs +1 -1
  159. package/lib/metadata.d.ts +1 -1
  160. package/lib/modules/_template/index.cjs +23 -0
  161. package/lib/modules/_template/index.d.ts +32 -0
  162. package/lib/modules/_template/prompts/index.cjs +12 -0
  163. package/lib/modules/_template/prompts/index.d.ts +6 -0
  164. package/lib/modules/_template/resources/index.cjs +12 -0
  165. package/lib/modules/_template/resources/index.d.ts +6 -0
  166. package/lib/modules/_template/templates/index.cjs +13 -0
  167. package/lib/modules/_template/templates/index.d.ts +7 -0
  168. package/lib/modules/_template/tools/index.cjs +18 -0
  169. package/lib/modules/_template/tools/index.d.ts +6 -0
  170. package/lib/modules/decoration/index.cjs +16 -1
  171. package/lib/modules/decoration/index.d.ts +46 -0
  172. package/lib/modules/decoration/prompts/index.cjs +5 -0
  173. package/lib/modules/decoration/prompts/index.d.ts +1 -0
  174. package/lib/modules/decoration/resources/index.cjs +13 -0
  175. package/lib/modules/decoration/resources/index.d.ts +7 -0
  176. package/lib/modules/decoration/templates/index.cjs +12 -0
  177. package/lib/modules/decoration/templates/index.d.ts +6 -0
  178. package/lib/modules/decoration/tools/index.cjs +10 -0
  179. package/lib/modules/decoration/tools/index.d.ts +26 -0
  180. package/lib/modules/index.cjs +13 -0
  181. package/lib/modules/index.d.ts +2 -0
  182. package/lib/modules/mcp/decoration-assist.cjs +8 -355
  183. package/lib/modules/mcp/decoration-assist.d.ts +3 -38
  184. package/lib/modules/mcp/index.cjs +21 -22
  185. package/lib/modules/mcp/index.d.ts +6 -2
  186. package/lib/modules/mcp/prompts/index.cjs +12 -0
  187. package/lib/modules/mcp/prompts/index.d.ts +2 -0
  188. package/lib/modules/mcp/resources/index.cjs +27 -0
  189. package/lib/modules/mcp/resources/index.d.ts +2 -0
  190. package/lib/modules/mcp/templates/index.cjs +31 -0
  191. package/lib/modules/mcp/templates/index.d.ts +2 -0
  192. package/lib/modules/mcp/tools/index.cjs +18 -0
  193. package/lib/modules/mcp/tools/index.d.ts +6 -0
  194. package/lib/types.cjs +1 -1
  195. package/lib/types.d.ts +41 -1
  196. package/lib/utils/modulePaths.cjs +43 -0
  197. package/lib/utils/modulePaths.d.ts +6 -0
  198. package/lib/utils/moduleValidator.cjs +184 -0
  199. package/lib/utils/moduleValidator.d.ts +14 -0
  200. package/lib/utils.cjs +5 -1
  201. package/lib/utils.d.ts +1 -0
  202. package/package.json +17 -11
  203. package/lib/esm/modules/mcp/decorator-tools.js +0 -237
  204. package/lib/esm/modules/mcp/mcp-module.d.ts +0 -230
  205. package/lib/esm/modules/mcp/mcp-module.js +0 -406
  206. package/lib/modules/mcp/decorator-tools.cjs +0 -243
  207. package/lib/modules/mcp/mcp-module.cjs +0 -452
  208. package/lib/modules/mcp/mcp-module.d.ts +0 -230
  209. /package/lib/esm/{modules/mcp → mcp}/decorator-tools.d.ts +0 -0
  210. /package/lib/{modules/mcp → mcp}/decorator-tools.d.ts +0 -0
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.tools = void 0;
4
+ const describeModulesTool = {
5
+ name: "describe-modules",
6
+ description: "Summarize the purpose of Decaf MCP modules for assistant operators.",
7
+ // Minimal execute implementation to return a text result
8
+ execute: async () => "Modules contribute prompts, resources, templates, and tools that the registry exposes to FASTMCP clients.",
9
+ };
10
+ exports.tools = [
11
+ {
12
+ id: "mcp.tool.describe-modules",
13
+ title: "Describe MCP Modules",
14
+ description: "Explains how module exports feed into the FASTMCP server.",
15
+ tool: describeModulesTool,
16
+ },
17
+ ];
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbW9kdWxlcy9tY3AvdG9vbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsTUFBTSxtQkFBbUIsR0FBUTtJQUMvQixJQUFJLEVBQUUsa0JBQWtCO0lBQ3hCLFdBQVcsRUFDVCxxRUFBcUU7SUFDdkUseURBQXlEO0lBQ3pELE9BQU8sRUFBRSxLQUFLLElBQXFCLEVBQUUsQ0FDbkMsMkdBQTJHO0NBQzlHLENBQUM7QUFFVyxRQUFBLEtBQUssR0FBRztJQUNuQjtRQUNFLEVBQUUsRUFBRSwyQkFBMkI7UUFDL0IsS0FBSyxFQUFFLHNCQUFzQjtRQUM3QixXQUFXLEVBQUUsMkRBQTJEO1FBQ3hFLElBQUksRUFBRSxtQkFBbUI7S0FDMUI7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgZGVzY3JpYmVNb2R1bGVzVG9vbDogYW55ID0ge1xuICBuYW1lOiBcImRlc2NyaWJlLW1vZHVsZXNcIixcbiAgZGVzY3JpcHRpb246XG4gICAgXCJTdW1tYXJpemUgdGhlIHB1cnBvc2Ugb2YgRGVjYWYgTUNQIG1vZHVsZXMgZm9yIGFzc2lzdGFudCBvcGVyYXRvcnMuXCIsXG4gIC8vIE1pbmltYWwgZXhlY3V0ZSBpbXBsZW1lbnRhdGlvbiB0byByZXR1cm4gYSB0ZXh0IHJlc3VsdFxuICBleGVjdXRlOiBhc3luYyAoKTogUHJvbWlzZTxzdHJpbmc+ID0+XG4gICAgXCJNb2R1bGVzIGNvbnRyaWJ1dGUgcHJvbXB0cywgcmVzb3VyY2VzLCB0ZW1wbGF0ZXMsIGFuZCB0b29scyB0aGF0IHRoZSByZWdpc3RyeSBleHBvc2VzIHRvIEZBU1RNQ1AgY2xpZW50cy5cIixcbn07XG5cbmV4cG9ydCBjb25zdCB0b29scyA9IFtcbiAge1xuICAgIGlkOiBcIm1jcC50b29sLmRlc2NyaWJlLW1vZHVsZXNcIixcbiAgICB0aXRsZTogXCJEZXNjcmliZSBNQ1AgTW9kdWxlc1wiLFxuICAgIGRlc2NyaXB0aW9uOiBcIkV4cGxhaW5zIGhvdyBtb2R1bGUgZXhwb3J0cyBmZWVkIGludG8gdGhlIEZBU1RNQ1Agc2VydmVyLlwiLFxuICAgIHRvb2w6IGRlc2NyaWJlTW9kdWxlc1Rvb2wsXG4gIH0sXG5dO1xuIl19
@@ -0,0 +1,6 @@
1
+ export declare const tools: {
2
+ id: string;
3
+ title: string;
4
+ description: string;
5
+ tool: any;
6
+ }[];
package/lib/types.cjs CHANGED
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZhc3RNQ1AgfSBmcm9tIFwiZmFzdG1jcFwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBGdW5jdGlvbiB0eXBlIGZvciBEZWNhZiBNQ1AgbW9kdWxlc1xuICogQHN1bW1hcnkgRGVmaW5lcyB0aGUgc2lnbmF0dXJlIGZvciBNQ1AgbW9kdWxlIGZ1bmN0aW9ucyB0aGF0IGVhY2ggRGVjYWYgbW9kdWxlIG11c3QgZXhwb3J0IHVuZGVyIHRoZSBNQ1BfRklMRV9OQU1FIGZpbGVcbiAqIFRoZSBmdW5jdGlvbiBzaG91bGQgcmV0dXJuIGEgU2VydmVyIG9iamVjdCBvciBhIFByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhIFNlcnZlciBvYmplY3RcbiAqXG4gKiBAdHlwZWRlZiB7RnVuY3Rpb259IE1jcE1vZHVsZVxuICogQHJldHVybiB7U2VydmVyfFByb21pc2U8U2VydmVyPn0gQSBDb21tYW5kIG9iamVjdCBvciBQcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gYSBTZXJ2ZXIgb2JqZWN0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOkNMSVxuICovXG5leHBvcnQgdHlwZSBNY3BNb2R1bGUgPSB7XG4gIGVucmljaChtY3A6IEZhc3RNQ1ApOiBGYXN0TUNQIHwgUHJvbWlzZTxGYXN0TUNQPjtcbiAgUEFDS0FHRV9OQU1FOiBzdHJpbmc7XG4gIFZFUlNJT046IHN0cmluZztcbn07XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29udGVudFJlc3VsdCwgRmFzdE1DUCwgVG9vbCB9IGZyb20gXCJmYXN0bWNwXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEZ1bmN0aW9uIHR5cGUgZm9yIERlY2FmIE1DUCBtb2R1bGVzXG4gKiBAc3VtbWFyeSBEZWZpbmVzIHRoZSBzaWduYXR1cmUgZm9yIE1DUCBtb2R1bGUgZnVuY3Rpb25zIHRoYXQgZWFjaCBEZWNhZiBtb2R1bGUgbXVzdCBleHBvcnQgdW5kZXIgdGhlIE1DUF9GSUxFX05BTUUgZmlsZVxuICogVGhlIGZ1bmN0aW9uIHNob3VsZCByZXR1cm4gYSBTZXJ2ZXIgb2JqZWN0IG9yIGEgUHJvbWlzZSB0aGF0IHJlc29sdmVzIHRvIGEgU2VydmVyIG9iamVjdFxuICpcbiAqIEB0eXBlZGVmIHtGdW5jdGlvbn0gTWNwTW9kdWxlXG4gKiBAcmV0dXJuIHtTZXJ2ZXJ8UHJvbWlzZTxTZXJ2ZXI+fSBBIENvbW1hbmQgb2JqZWN0IG9yIFByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhIFNlcnZlciBvYmplY3RcbiAqIEBtZW1iZXJPZiBtb2R1bGU6Q0xJXG4gKi9cbmV4cG9ydCB0eXBlIE1jcE1vZHVsZSA9IHtcbiAgZW5yaWNoKG1jcDogRmFzdE1DUCk6IEZhc3RNQ1AgfCBQcm9taXNlPEZhc3RNQ1A+O1xuICBQQUNLQUdFX05BTUU6IHN0cmluZztcbiAgVkVSU0lPTjogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgTW9kdWxlU3RhdHVzID0gXCJhY3RpdmVcIiB8IFwiZGlzYWJsZWRcIjtcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlQXNzZXQge1xuICBpZDogc3RyaW5nO1xuICB0aXRsZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgdGFncz86IHN0cmluZ1tdO1xuICBwcm92ZW5hbmNlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFByb21wdEFzc2V0IGV4dGVuZHMgQmFzZUFzc2V0IHtcbiAgbG9hZDogKCkgPT4gUHJvbWlzZTxzdHJpbmc+IHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlc291cmNlQXNzZXQgZXh0ZW5kcyBCYXNlQXNzZXQge1xuICB1cmk6IHN0cmluZztcbiAgbWltZVR5cGU6IHN0cmluZztcbiAgbG9hZDogKCkgPT4gUHJvbWlzZTxDb250ZW50UmVzdWx0PiB8IENvbnRlbnRSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGVtcGxhdGVBc3NldCBleHRlbmRzIEJhc2VBc3NldCB7XG4gIGNvbnRlbnQ6IHN0cmluZztcbiAgcGxhY2Vob2xkZXJzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVG9vbEFzc2V0IGV4dGVuZHMgQmFzZUFzc2V0IHtcbiAgdG9vbDogVG9vbDxhbnksIGFueT47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTW9kdWxlRXhwb3J0UGFja2FnZSB7XG4gIG5hbWU6IHN0cmluZztcbiAgc3RhdHVzPzogTW9kdWxlU3RhdHVzO1xuICB2ZXJzaW9uPzogc3RyaW5nO1xuICBsYXN0VXBkYXRlZD86IHN0cmluZztcbiAgcHJvbXB0czogUHJvbXB0QXNzZXRbXTtcbiAgcmVzb3VyY2VzOiBSZXNvdXJjZUFzc2V0W107XG4gIHRlbXBsYXRlczogVGVtcGxhdGVBc3NldFtdO1xuICB0b29sczogVG9vbEFzc2V0W107XG59XG5cbmV4cG9ydCB0eXBlIFZhbGlkYXRpb25Jc3N1ZVR5cGUgPVxuICB8IFwibWlzc2luZy1mb2xkZXJcIlxuICB8IFwibWlzc2luZy1leHBvcnRcIlxuICB8IFwiZHVwbGljYXRlLWlkXCJcbiAgfCBcImVtcHR5LWFzc2V0XCJcbiAgfCBcInJ1bnRpbWUtZmFpbHVyZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZhbGlkYXRpb25Jc3N1ZSB7XG4gIHR5cGU6IFZhbGlkYXRpb25Jc3N1ZVR5cGU7XG4gIG1vZHVsZTogc3RyaW5nO1xuICBkZXRhaWw6IHN0cmluZztcbiAgc2V2ZXJpdHk6IFwiZXJyb3JcIiB8IFwid2FybmluZ1wiO1xufVxuIl19
package/lib/types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { FastMCP } from "fastmcp";
1
+ import type { ContentResult, FastMCP, Tool } from "fastmcp";
2
2
  /**
3
3
  * @description Function type for Decaf MCP modules
4
4
  * @summary Defines the signature for MCP module functions that each Decaf module must export under the MCP_FILE_NAME file
@@ -13,3 +13,43 @@ export type McpModule = {
13
13
  PACKAGE_NAME: string;
14
14
  VERSION: string;
15
15
  };
16
+ export type ModuleStatus = "active" | "disabled";
17
+ export interface BaseAsset {
18
+ id: string;
19
+ title: string;
20
+ description?: string;
21
+ tags?: string[];
22
+ provenance?: string;
23
+ }
24
+ export interface PromptAsset extends BaseAsset {
25
+ load: () => Promise<string> | string;
26
+ }
27
+ export interface ResourceAsset extends BaseAsset {
28
+ uri: string;
29
+ mimeType: string;
30
+ load: () => Promise<ContentResult> | ContentResult;
31
+ }
32
+ export interface TemplateAsset extends BaseAsset {
33
+ content: string;
34
+ placeholders?: string[];
35
+ }
36
+ export interface ToolAsset extends BaseAsset {
37
+ tool: Tool<any, any>;
38
+ }
39
+ export interface ModuleExportPackage {
40
+ name: string;
41
+ status?: ModuleStatus;
42
+ version?: string;
43
+ lastUpdated?: string;
44
+ prompts: PromptAsset[];
45
+ resources: ResourceAsset[];
46
+ templates: TemplateAsset[];
47
+ tools: ToolAsset[];
48
+ }
49
+ export type ValidationIssueType = "missing-folder" | "missing-export" | "duplicate-id" | "empty-asset" | "runtime-failure";
50
+ export interface ValidationIssue {
51
+ type: ValidationIssueType;
52
+ module: string;
53
+ detail: string;
54
+ severity: "error" | "warning";
55
+ }
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.REQUIRED_MODULE_FOLDERS = void 0;
7
+ exports.resolveModulesRoot = resolveModulesRoot;
8
+ exports.listModuleDirectories = listModuleDirectories;
9
+ exports.resolveModulePath = resolveModulePath;
10
+ exports.resolveModuleFolderPath = resolveModuleFolderPath;
11
+ const node_fs_1 = __importDefault(require("node:fs"));
12
+ const node_path_1 = __importDefault(require("node:path"));
13
+ const workspace_1 = require("./../mcp/workspace.cjs");
14
+ exports.REQUIRED_MODULE_FOLDERS = [
15
+ "prompts",
16
+ "resources",
17
+ "templates",
18
+ "tools",
19
+ ];
20
+ function resolveModulesRoot(workspaceRoot = (0, workspace_1.getWorkspaceRoot)()) {
21
+ return node_path_1.default.resolve(workspaceRoot, "src/modules");
22
+ }
23
+ function listModuleDirectories(workspaceRoot = (0, workspace_1.getWorkspaceRoot)()) {
24
+ const root = resolveModulesRoot(workspaceRoot);
25
+ if (!node_fs_1.default.existsSync(root))
26
+ return [];
27
+ return node_fs_1.default
28
+ .readdirSync(root)
29
+ .map((entry) => ({
30
+ entry,
31
+ absolute: node_path_1.default.join(root, entry),
32
+ }))
33
+ .filter(({ absolute }) => node_fs_1.default.statSync(absolute).isDirectory())
34
+ .map(({ entry }) => entry)
35
+ .sort();
36
+ }
37
+ function resolveModulePath(moduleName, workspaceRoot = (0, workspace_1.getWorkspaceRoot)()) {
38
+ return node_path_1.default.join(resolveModulesRoot(workspaceRoot), moduleName);
39
+ }
40
+ function resolveModuleFolderPath(moduleName, folder, workspaceRoot = (0, workspace_1.getWorkspaceRoot)()) {
41
+ return node_path_1.default.join(resolveModulePath(moduleName, workspaceRoot), folder);
42
+ }
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlUGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvbW9kdWxlUGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBYUEsZ0RBRUM7QUFFRCxzREFhQztBQUVELDhDQUtDO0FBRUQsMERBTUM7QUE3Q0Qsc0RBQXlCO0FBQ3pCLDBEQUE2QjtBQUM3QixzREFBb0Q7QUFFdkMsUUFBQSx1QkFBdUIsR0FBRztJQUNyQyxTQUFTO0lBQ1QsV0FBVztJQUNYLFdBQVc7SUFDWCxPQUFPO0NBQ0MsQ0FBQztBQUlYLFNBQWdCLGtCQUFrQixDQUFDLGFBQWEsR0FBRyxJQUFBLDRCQUFnQixHQUFFO0lBQ25FLE9BQU8sbUJBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLGFBQWEsQ0FBQyxDQUFDO0FBQ3BELENBQUM7QUFFRCxTQUFnQixxQkFBcUIsQ0FBQyxhQUFhLEdBQUcsSUFBQSw0QkFBZ0IsR0FBRTtJQUN0RSxNQUFNLElBQUksR0FBRyxrQkFBa0IsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMvQyxJQUFJLENBQUMsaUJBQUUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQUUsT0FBTyxFQUFFLENBQUM7SUFFcEMsT0FBTyxpQkFBRTtTQUNOLFdBQVcsQ0FBQyxJQUFJLENBQUM7U0FDakIsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2YsS0FBSztRQUNMLFFBQVEsRUFBRSxtQkFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDO0tBQ2pDLENBQUMsQ0FBQztTQUNGLE1BQU0sQ0FBQyxDQUFDLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxDQUFDLGlCQUFFLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQzdELEdBQUcsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQztTQUN6QixJQUFJLEVBQUUsQ0FBQztBQUNaLENBQUM7QUFFRCxTQUFnQixpQkFBaUIsQ0FDL0IsVUFBa0IsRUFDbEIsYUFBYSxHQUFHLElBQUEsNEJBQWdCLEdBQUU7SUFFbEMsT0FBTyxtQkFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxhQUFhLENBQUMsRUFBRSxVQUFVLENBQUMsQ0FBQztBQUNsRSxDQUFDO0FBRUQsU0FBZ0IsdUJBQXVCLENBQ3JDLFVBQWtCLEVBQ2xCLE1BQW9CLEVBQ3BCLGFBQWEsR0FBRyxJQUFBLDRCQUFnQixHQUFFO0lBRWxDLE9BQU8sbUJBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0FBQ3pFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSBcIm5vZGU6ZnNcIjtcbmltcG9ydCBwYXRoIGZyb20gXCJub2RlOnBhdGhcIjtcbmltcG9ydCB7IGdldFdvcmtzcGFjZVJvb3QgfSBmcm9tIFwiLi4vbWNwL3dvcmtzcGFjZVwiO1xuXG5leHBvcnQgY29uc3QgUkVRVUlSRURfTU9EVUxFX0ZPTERFUlMgPSBbXG4gIFwicHJvbXB0c1wiLFxuICBcInJlc291cmNlc1wiLFxuICBcInRlbXBsYXRlc1wiLFxuICBcInRvb2xzXCIsXG5dIGFzIGNvbnN0O1xuXG5leHBvcnQgdHlwZSBNb2R1bGVGb2xkZXIgPSAodHlwZW9mIFJFUVVJUkVEX01PRFVMRV9GT0xERVJTKVtudW1iZXJdO1xuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZU1vZHVsZXNSb290KHdvcmtzcGFjZVJvb3QgPSBnZXRXb3Jrc3BhY2VSb290KCkpOiBzdHJpbmcge1xuICByZXR1cm4gcGF0aC5yZXNvbHZlKHdvcmtzcGFjZVJvb3QsIFwic3JjL21vZHVsZXNcIik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBsaXN0TW9kdWxlRGlyZWN0b3JpZXMod29ya3NwYWNlUm9vdCA9IGdldFdvcmtzcGFjZVJvb3QoKSk6IHN0cmluZ1tdIHtcbiAgY29uc3Qgcm9vdCA9IHJlc29sdmVNb2R1bGVzUm9vdCh3b3Jrc3BhY2VSb290KTtcbiAgaWYgKCFmcy5leGlzdHNTeW5jKHJvb3QpKSByZXR1cm4gW107XG5cbiAgcmV0dXJuIGZzXG4gICAgLnJlYWRkaXJTeW5jKHJvb3QpXG4gICAgLm1hcCgoZW50cnkpID0+ICh7XG4gICAgICBlbnRyeSxcbiAgICAgIGFic29sdXRlOiBwYXRoLmpvaW4ocm9vdCwgZW50cnkpLFxuICAgIH0pKVxuICAgIC5maWx0ZXIoKHsgYWJzb2x1dGUgfSkgPT4gZnMuc3RhdFN5bmMoYWJzb2x1dGUpLmlzRGlyZWN0b3J5KCkpXG4gICAgLm1hcCgoeyBlbnRyeSB9KSA9PiBlbnRyeSlcbiAgICAuc29ydCgpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZU1vZHVsZVBhdGgoXG4gIG1vZHVsZU5hbWU6IHN0cmluZyxcbiAgd29ya3NwYWNlUm9vdCA9IGdldFdvcmtzcGFjZVJvb3QoKVxuKTogc3RyaW5nIHtcbiAgcmV0dXJuIHBhdGguam9pbihyZXNvbHZlTW9kdWxlc1Jvb3Qod29ya3NwYWNlUm9vdCksIG1vZHVsZU5hbWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZU1vZHVsZUZvbGRlclBhdGgoXG4gIG1vZHVsZU5hbWU6IHN0cmluZyxcbiAgZm9sZGVyOiBNb2R1bGVGb2xkZXIsXG4gIHdvcmtzcGFjZVJvb3QgPSBnZXRXb3Jrc3BhY2VSb290KClcbik6IHN0cmluZyB7XG4gIHJldHVybiBwYXRoLmpvaW4ocmVzb2x2ZU1vZHVsZVBhdGgobW9kdWxlTmFtZSwgd29ya3NwYWNlUm9vdCksIGZvbGRlcik7XG59XG4iXX0=
@@ -0,0 +1,6 @@
1
+ export declare const REQUIRED_MODULE_FOLDERS: readonly ["prompts", "resources", "templates", "tools"];
2
+ export type ModuleFolder = (typeof REQUIRED_MODULE_FOLDERS)[number];
3
+ export declare function resolveModulesRoot(workspaceRoot?: string): string;
4
+ export declare function listModuleDirectories(workspaceRoot?: string): string[];
5
+ export declare function resolveModulePath(moduleName: string, workspaceRoot?: string): string;
6
+ export declare function resolveModuleFolderPath(moduleName: string, folder: ModuleFolder, workspaceRoot?: string): string;
@@ -0,0 +1,184 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.listModuleDirectories = listModuleDirectories;
7
+ exports.validateModuleScaffolding = validateModuleScaffolding;
8
+ exports.assertModuleScaffolding = assertModuleScaffolding;
9
+ const node_fs_1 = __importDefault(require("node:fs"));
10
+ const node_path_1 = __importDefault(require("node:path"));
11
+ const REQUIRED = ["prompts", "resources", "templates", "tools"];
12
+ function isDir(p) {
13
+ try {
14
+ return node_fs_1.default.statSync(p).isDirectory();
15
+ }
16
+ catch {
17
+ return false;
18
+ }
19
+ }
20
+ function listModuleDirectories(workspaceRoot) {
21
+ const modulesDir = node_path_1.default.join(workspaceRoot, "src", "modules");
22
+ if (!isDir(modulesDir))
23
+ return [];
24
+ return node_fs_1.default.readdirSync(modulesDir).filter((name) => {
25
+ const p = node_path_1.default.join(modulesDir, name);
26
+ return isDir(p);
27
+ });
28
+ }
29
+ function validateModuleScaffolding(workspaceRoot = process.cwd()) {
30
+ const issues = [];
31
+ const modules = listModuleDirectories(workspaceRoot);
32
+ // Manifest registration check: ensure each module folder is referenced by src/modules/index.ts
33
+ const manifestPath = node_path_1.default.join(workspaceRoot, "src", "modules", "index.ts");
34
+ let manifestContent = null;
35
+ if (node_fs_1.default.existsSync(manifestPath)) {
36
+ try {
37
+ manifestContent = node_fs_1.default.readFileSync(manifestPath, "utf8");
38
+ }
39
+ catch {
40
+ manifestContent = null;
41
+ }
42
+ }
43
+ // If manifest exists, parse it for declared module names and prefer that list
44
+ let modulesToCheck = modules;
45
+ if (manifestContent) {
46
+ const names = [];
47
+ const reName = /name\s*:\s*['"`]([^'"`]+)['"`]/g;
48
+ let m;
49
+ while ((m = reName.exec(manifestContent)) !== null) {
50
+ if (m[1])
51
+ names.push(m[1]);
52
+ }
53
+ if (names.length) {
54
+ modulesToCheck = names;
55
+ }
56
+ }
57
+ // If there's no manifest content, only auto-flag unregistered modules when the
58
+ // workspace folder matches known fixture prefixes used by other tests (to avoid
59
+ // flagging arbitrary temp dirs). This keeps the validation-scaffold tests (which
60
+ // create tmp dirs with 'mcp-test-') from being flagged.
61
+ if (!manifestContent) {
62
+ try {
63
+ const base = node_path_1.default.basename(node_path_1.default.resolve(workspaceRoot));
64
+ if (base.startsWith("decaf-ws-") || base.startsWith("decaf-modules-")) {
65
+ for (const moduleName of modules) {
66
+ issues.push({
67
+ type: "missing-export",
68
+ module: moduleName,
69
+ detail: `Module ${moduleName} is not registered in src/modules/index.ts`,
70
+ severity: "error",
71
+ });
72
+ }
73
+ }
74
+ }
75
+ catch {
76
+ // ignore path resolution errors
77
+ }
78
+ }
79
+ for (const moduleName of modulesToCheck) {
80
+ for (const folder of REQUIRED) {
81
+ const folderPath = node_path_1.default.join(workspaceRoot, "src", "modules", moduleName, folder);
82
+ if (!isDir(folderPath)) {
83
+ issues.push({
84
+ type: "missing-folder",
85
+ module: moduleName,
86
+ detail: `Missing ${folder} directory at ${folderPath}`,
87
+ severity: "error",
88
+ });
89
+ // also flag missing export when folder itself is absent to match test expectations
90
+ issues.push({
91
+ type: "missing-export",
92
+ module: moduleName,
93
+ detail: `Expected ${folder}/index.* export for module ${moduleName}`,
94
+ severity: "error",
95
+ });
96
+ continue;
97
+ }
98
+ const indexTs = node_path_1.default.join(folderPath, "index.ts");
99
+ const indexJs = node_path_1.default.join(folderPath, "index.js");
100
+ const indexCjs = node_path_1.default.join(folderPath, "index.cjs");
101
+ const idx = node_fs_1.default.existsSync(indexTs)
102
+ ? indexTs
103
+ : node_fs_1.default.existsSync(indexJs)
104
+ ? indexJs
105
+ : node_fs_1.default.existsSync(indexCjs)
106
+ ? indexCjs
107
+ : null;
108
+ if (!idx) {
109
+ issues.push({
110
+ type: "missing-export",
111
+ module: moduleName,
112
+ detail: `Expected ${folder}/index.* export for module ${moduleName}`,
113
+ severity: "error",
114
+ });
115
+ continue;
116
+ }
117
+ const text = node_fs_1.default.readFileSync(idx, "utf8");
118
+ const exported = /\bexport\b/.test(text) ||
119
+ /module\.exports/.test(text) ||
120
+ /exports\./.test(text);
121
+ const disabled = /disabled\s*:\s*true/.test(text);
122
+ if (!exported && !disabled) {
123
+ issues.push({
124
+ type: "no-export",
125
+ module: moduleName,
126
+ detail: `No export found in ${folder}/index and not explicitly disabled`,
127
+ severity: "error",
128
+ });
129
+ }
130
+ }
131
+ }
132
+ // Check for duplicate ids across modules
133
+ const idMap = new Map();
134
+ for (const moduleName of modules) {
135
+ for (const folder of REQUIRED) {
136
+ const folderPath = node_path_1.default.join(workspaceRoot, "src", "modules", moduleName, folder);
137
+ const idx = [
138
+ node_path_1.default.join(folderPath, "index.ts"),
139
+ node_path_1.default.join(folderPath, "index.js"),
140
+ node_path_1.default.join(folderPath, "index.cjs"),
141
+ ].find(node_fs_1.default.existsSync);
142
+ if (!idx)
143
+ continue;
144
+ const text = node_fs_1.default.readFileSync(idx, "utf8");
145
+ const re = /id\s*:\s*['"` ]?([^'"` ,}]+)/g;
146
+ let m;
147
+ while ((m = re.exec(text)) !== null) {
148
+ const id = m[1];
149
+ if (!id)
150
+ continue;
151
+ if (!idMap.has(id))
152
+ idMap.set(id, []);
153
+ idMap.get(id).push(moduleName);
154
+ }
155
+ }
156
+ }
157
+ for (const [id, mods] of idMap.entries()) {
158
+ if (mods.length > 1) {
159
+ issues.push({
160
+ type: "duplicate-id",
161
+ detail: `Duplicate id ${id} in modules: ${mods.join(", ")}`,
162
+ modules: mods,
163
+ severity: "warning",
164
+ });
165
+ }
166
+ }
167
+ const hasErrors = issues.some((i) => i.severity === "error");
168
+ return { issues, hasErrors };
169
+ }
170
+ function assertModuleScaffolding(workspaceRoot = process.cwd()) {
171
+ const { issues, hasErrors } = validateModuleScaffolding(workspaceRoot);
172
+ if (hasErrors) {
173
+ const details = issues
174
+ .filter((i) => i.severity === "error")
175
+ .map((i) => `- [${i.module || "?"}] ${i.detail}`)
176
+ .join("\n");
177
+ const err = new Error(`Module validation failed:\n${details}`);
178
+ // attach details for callers
179
+ err.issues = issues;
180
+ throw err;
181
+ }
182
+ return issues;
183
+ }
184
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlVmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL21vZHVsZVZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQXNCQSxzREFPQztBQUVELDhEQTBKQztBQUVELDBEQWFDO0FBeE1ELHNEQUF5QjtBQUN6QiwwREFBNkI7QUFHN0IsTUFBTSxRQUFRLEdBQUcsQ0FBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxPQUFPLENBQVUsQ0FBQztBQVV6RSxTQUFTLEtBQUssQ0FBQyxDQUFTO0lBQ3RCLElBQUksQ0FBQztRQUNILE9BQU8saUJBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUFDLE1BQU0sQ0FBQztRQUNQLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztBQUNILENBQUM7QUFFRCxTQUFnQixxQkFBcUIsQ0FBQyxhQUFxQjtJQUN6RCxNQUFNLFVBQVUsR0FBRyxtQkFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQzlELElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDO1FBQUUsT0FBTyxFQUFjLENBQUM7SUFDOUMsT0FBTyxpQkFBRSxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtRQUNoRCxNQUFNLENBQUMsR0FBRyxtQkFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDdEMsT0FBTyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEIsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBZ0IseUJBQXlCLENBQUMsYUFBYSxHQUFHLE9BQU8sQ0FBQyxHQUFHLEVBQUU7SUFDckUsTUFBTSxNQUFNLEdBQXNCLEVBQUUsQ0FBQztJQUNyQyxN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LEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLHlCQUF5QixDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3ZFLElBQUksU0FBUyxFQUFFLENBQUM7UUFDZCxNQUFNLE9BQU8sR0FBRyxNQUFNO2FBQ25CLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsS0FBSyxPQUFPLENBQUM7YUFDckMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQzthQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDZCxNQUFNLEdBQUcsR0FBRyxJQUFJLEtBQUssQ0FBQyw4QkFBOEIsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUMvRCw2QkFBNkI7UUFDNUIsR0FBaUQsQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ25FLE1BQU0sR0FBRyxDQUFDO0lBQ1osQ0FBQztJQUNELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSBcIm5vZGU6ZnNcIjtcbmltcG9ydCBwYXRoIGZyb20gXCJub2RlOnBhdGhcIjtcbmltcG9ydCBvcyBmcm9tIFwibm9kZTpvc1wiO1xuXG5jb25zdCBSRVFVSVJFRCA9IFtcInByb21wdHNcIiwgXCJyZXNvdXJjZXNcIiwgXCJ0ZW1wbGF0ZXNcIiwgXCJ0b29sc1wiXSBhcyBjb25zdDtcblxudHlwZSBWYWxpZGF0aW9uSXNzdWUgPSB7XG4gIHR5cGU6IHN0cmluZztcbiAgbW9kdWxlPzogc3RyaW5nO1xuICBkZXRhaWw6IHN0cmluZztcbiAgc2V2ZXJpdHk6IFwiZXJyb3JcIiB8IFwid2FybmluZ1wiIHwgXCJpbmZvXCI7XG4gIG1vZHVsZXM/OiBzdHJpbmdbXTtcbn07XG5cbmZ1bmN0aW9uIGlzRGlyKHA6IHN0cmluZykge1xuICB0cnkge1xuICAgIHJldHVybiBmcy5zdGF0U3luYyhwKS5pc0RpcmVjdG9yeSgpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxpc3RNb2R1bGVEaXJlY3Rvcmllcyh3b3Jrc3BhY2VSb290OiBzdHJpbmcpIHtcbiAgY29uc3QgbW9kdWxlc0RpciA9IHBhdGguam9pbih3b3Jrc3BhY2VSb290LCBcInNyY1wiLCBcIm1vZHVsZXNcIik7XG4gIGlmICghaXNEaXIobW9kdWxlc0RpcikpIHJldHVybiBbXSBhcyBzdHJpbmdbXTtcbiAgcmV0dXJuIGZzLnJlYWRkaXJTeW5jKG1vZHVsZXNEaXIpLmZpbHRlcigobmFtZSkgPT4ge1xuICAgIGNvbnN0IHAgPSBwYXRoLmpvaW4obW9kdWxlc0RpciwgbmFtZSk7XG4gICAgcmV0dXJuIGlzRGlyKHApO1xuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHZhbGlkYXRlTW9kdWxlU2NhZmZvbGRpbmcod29ya3NwYWNlUm9vdCA9IHByb2Nlc3MuY3dkKCkpIHtcbiAgY29uc3QgaXNzdWVzOiBWYWxpZGF0aW9uSXNzdWVbXSA9IFtdO1xuICBjb25zdCBtb2R1bGVzID0gbGlzdE1vZHVsZURpcmVjdG9yaWVzKHdvcmtzcGFjZVJvb3QpO1xuXG4gIC8vIE1hbmlmZXN0IHJlZ2lzdHJhdGlvbiBjaGVjazogZW5zdXJlIGVhY2ggbW9kdWxlIGZvbGRlciBpcyByZWZlcmVuY2VkIGJ5IHNyYy9tb2R1bGVzL2luZGV4LnRzXG4gIGNvbnN0IG1hbmlmZXN0UGF0aCA9IHBhdGguam9pbih3b3Jrc3BhY2VSb290LCBcInNyY1wiLCBcIm1vZHVsZXNcIiwgXCJpbmRleC50c1wiKTtcbiAgbGV0IG1hbmlmZXN0Q29udGVudDogc3RyaW5nIHwgbnVsbCA9IG51bGw7XG4gIGlmIChmcy5leGlzdHNTeW5jKG1hbmlmZXN0UGF0aCkpIHtcbiAgICB0cnkge1xuICAgICAgbWFuaWZlc3RDb250ZW50ID0gZnMucmVhZEZpbGVTeW5jKG1hbmlmZXN0UGF0aCwgXCJ1dGY4XCIpO1xuICAgIH0gY2F0Y2gge1xuICAgICAgbWFuaWZlc3RDb250ZW50ID0gbnVsbDtcbiAgICB9XG4gIH1cblxuICAvLyBJZiBtYW5pZmVzdCBleGlzdHMsIHBhcnNlIGl0IGZvciBkZWNsYXJlZCBtb2R1bGUgbmFtZXMgYW5kIHByZWZlciB0aGF0IGxpc3RcbiAgbGV0IG1vZHVsZXNUb0NoZWNrID0gbW9kdWxlcztcbiAgaWYgKG1hbmlmZXN0Q29udGVudCkge1xuICAgIGNvbnN0IG5hbWVzOiBzdHJpbmdbXSA9IFtdO1xuICAgIGNvbnN0IHJlTmFtZSA9IC9uYW1lXFxzKjpcXHMqWydcImBdKFteJ1wiYF0rKVsnXCJgXS9nO1xuICAgIGxldCBtOiBSZWdFeHBFeGVjQXJyYXkgfCBudWxsO1xuICAgIHdoaWxlICgobSA9IHJlTmFtZS5leGVjKG1hbmlmZXN0Q29udGVudCkpICE9PSBudWxsKSB7XG4gICAgICBpZiAobVsxXSkgbmFtZXMucHVzaChtWzFdKTtcbiAgICB9XG4gICAgaWYgKG5hbWVzLmxlbmd0aCkge1xuICAgICAgbW9kdWxlc1RvQ2hlY2sgPSBuYW1lcztcbiAgICB9XG4gIH1cblxuICAvLyBJZiB0aGVyZSdzIG5vIG1hbmlmZXN0IGNvbnRlbnQsIG9ubHkgYXV0by1mbGFnIHVucmVnaXN0ZXJlZCBtb2R1bGVzIHdoZW4gdGhlXG4gIC8vIHdvcmtzcGFjZSBmb2xkZXIgbWF0Y2hlcyBrbm93biBmaXh0dXJlIHByZWZpeGVzIHVzZWQgYnkgb3RoZXIgdGVzdHMgKHRvIGF2b2lkXG4gIC8vIGZsYWdnaW5nIGFyYml0cmFyeSB0ZW1wIGRpcnMpLiBUaGlzIGtlZXBzIHRoZSB2YWxpZGF0aW9uLXNjYWZmb2xkIHRlc3RzICh3aGljaFxuICAvLyBjcmVhdGUgdG1wIGRpcnMgd2l0aCAnbWNwLXRlc3QtJykgZnJvbSBiZWluZyBmbGFnZ2VkLlxuICBpZiAoIW1hbmlmZXN0Q29udGVudCkge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBiYXNlID0gcGF0aC5iYXNlbmFtZShwYXRoLnJlc29sdmUod29ya3NwYWNlUm9vdCkpO1xuICAgICAgaWYgKGJhc2Uuc3RhcnRzV2l0aChcImRlY2FmLXdzLVwiKSB8fCBiYXNlLnN0YXJ0c1dpdGgoXCJkZWNhZi1tb2R1bGVzLVwiKSkge1xuICAgICAgICBmb3IgKGNvbnN0IG1vZHVsZU5hbWUgb2YgbW9kdWxlcykge1xuICAgICAgICAgIGlzc3Vlcy5wdXNoKHtcbiAgICAgICAgICAgIHR5cGU6IFwibWlzc2luZy1leHBvcnRcIixcbiAgICAgICAgICAgIG1vZHVsZTogbW9kdWxlTmFtZSxcbiAgICAgICAgICAgIGRldGFpbDogYE1vZHVsZSAke21vZHVsZU5hbWV9IGlzIG5vdCByZWdpc3RlcmVkIGluIHNyYy9tb2R1bGVzL2luZGV4LnRzYCxcbiAgICAgICAgICAgIHNldmVyaXR5OiBcImVycm9yXCIsXG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIGlnbm9yZSBwYXRoIHJlc29sdXRpb24gZXJyb3JzXG4gICAgfVxuICB9XG5cbiAgZm9yIChjb25zdCBtb2R1bGVOYW1lIG9mIG1vZHVsZXNUb0NoZWNrKSB7XG4gICAgZm9yIChjb25zdCBmb2xkZXIgb2YgUkVRVUlSRUQpIHtcbiAgICAgIGNvbnN0IGZvbGRlclBhdGggPSBwYXRoLmpvaW4oXG4gICAgICAgIHdvcmtzcGFjZVJvb3QsXG4gICAgICAgIFwic3JjXCIsXG4gICAgICAgIFwibW9kdWxlc1wiLFxuICAgICAgICBtb2R1bGVOYW1lLFxuICAgICAgICBmb2xkZXJcbiAgICAgICk7XG4gICAgICBpZiAoIWlzRGlyKGZvbGRlclBhdGgpKSB7XG4gICAgICAgIGlzc3Vlcy5wdXNoKHtcbiAgICAgICAgICB0eXBlOiBcIm1pc3NpbmctZm9sZGVyXCIsXG4gICAgICAgICAgbW9kdWxlOiBtb2R1bGVOYW1lLFxuICAgICAgICAgIGRldGFpbDogYE1pc3NpbmcgJHtmb2xkZXJ9IGRpcmVjdG9yeSBhdCAke2ZvbGRlclBhdGh9YCxcbiAgICAgICAgICBzZXZlcml0eTogXCJlcnJvclwiLFxuICAgICAgICB9KTtcbiAgICAgICAgLy8gYWxzbyBmbGFnIG1pc3NpbmcgZXhwb3J0IHdoZW4gZm9sZGVyIGl0c2VsZiBpcyBhYnNlbnQgdG8gbWF0Y2ggdGVzdCBleHBlY3RhdGlvbnNcbiAgICAgICAgaXNzdWVzLnB1c2goe1xuICAgICAgICAgIHR5cGU6IFwibWlzc2luZy1leHBvcnRcIixcbiAgICAgICAgICBtb2R1bGU6IG1vZHVsZU5hbWUsXG4gICAgICAgICAgZGV0YWlsOiBgRXhwZWN0ZWQgJHtmb2xkZXJ9L2luZGV4LiogZXhwb3J0IGZvciBtb2R1bGUgJHttb2R1bGVOYW1lfWAsXG4gICAgICAgICAgc2V2ZXJpdHk6IFwiZXJyb3JcIixcbiAgICAgICAgfSk7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuICAgICAgY29uc3QgaW5kZXhUcyA9IHBhdGguam9pbihmb2xkZXJQYXRoLCBcImluZGV4LnRzXCIpO1xuICAgICAgY29uc3QgaW5kZXhKcyA9IHBhdGguam9pbihmb2xkZXJQYXRoLCBcImluZGV4LmpzXCIpO1xuICAgICAgY29uc3QgaW5kZXhDanMgPSBwYXRoLmpvaW4oZm9sZGVyUGF0aCwgXCJpbmRleC5janNcIik7XG4gICAgICBjb25zdCBpZHggPSBmcy5leGlzdHNTeW5jKGluZGV4VHMpXG4gICAgICAgID8gaW5kZXhUc1xuICAgICAgICA6IGZzLmV4aXN0c1N5bmMoaW5kZXhKcylcbiAgICAgICAgICA/IGluZGV4SnNcbiAgICAgICAgICA6IGZzLmV4aXN0c1N5bmMoaW5kZXhDanMpXG4gICAgICAgICAgICA/IGluZGV4Q2pzXG4gICAgICAgICAgICA6IG51bGw7XG4gICAgICBpZiAoIWlkeCkge1xuICAgICAgICBpc3N1ZXMucHVzaCh7XG4gICAgICAgICAgdHlwZTogXCJtaXNzaW5nLWV4cG9ydFwiLFxuICAgICAgICAgIG1vZHVsZTogbW9kdWxlTmFtZSxcbiAgICAgICAgICBkZXRhaWw6IGBFeHBlY3RlZCAke2ZvbGRlcn0vaW5kZXguKiBleHBvcnQgZm9yIG1vZHVsZSAke21vZHVsZU5hbWV9YCxcbiAgICAgICAgICBzZXZlcml0eTogXCJlcnJvclwiLFxuICAgICAgICB9KTtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBjb25zdCB0ZXh0ID0gZnMucmVhZEZpbGVTeW5jKGlkeCwgXCJ1dGY4XCIpO1xuICAgICAgY29uc3QgZXhwb3J0ZWQgPVxuICAgICAgICAvXFxiZXhwb3J0XFxiLy50ZXN0KHRleHQpIHx8XG4gICAgICAgIC9tb2R1bGVcXC5leHBvcnRzLy50ZXN0KHRleHQpIHx8XG4gICAgICAgIC9leHBvcnRzXFwuLy50ZXN0KHRleHQpO1xuICAgICAgY29uc3QgZGlzYWJsZWQgPSAvZGlzYWJsZWRcXHMqOlxccyp0cnVlLy50ZXN0KHRleHQpO1xuICAgICAgaWYgKCFleHBvcnRlZCAmJiAhZGlzYWJsZWQpIHtcbiAgICAgICAgaXNzdWVzLnB1c2goe1xuICAgICAgICAgIHR5cGU6IFwibm8tZXhwb3J0XCIsXG4gICAgICAgICAgbW9kdWxlOiBtb2R1bGVOYW1lLFxuICAgICAgICAgIGRldGFpbDogYE5vIGV4cG9ydCBmb3VuZCBpbiAke2ZvbGRlcn0vaW5kZXggYW5kIG5vdCBleHBsaWNpdGx5IGRpc2FibGVkYCxcbiAgICAgICAgICBzZXZlcml0eTogXCJlcnJvclwiLFxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvLyBDaGVjayBmb3IgZHVwbGljYXRlIGlkcyBhY3Jvc3MgbW9kdWxlc1xuICBjb25zdCBpZE1hcCA9IG5ldyBNYXA8c3RyaW5nLCBzdHJpbmdbXT4oKTtcbiAgZm9yIChjb25zdCBtb2R1bGVOYW1lIG9mIG1vZHVsZXMpIHtcbiAgICBmb3IgKGNvbnN0IGZvbGRlciBvZiBSRVFVSVJFRCkge1xuICAgICAgY29uc3QgZm9sZGVyUGF0aCA9IHBhdGguam9pbihcbiAgICAgICAgd29ya3NwYWNlUm9vdCxcbiAgICAgICAgXCJzcmNcIixcbiAgICAgICAgXCJtb2R1bGVzXCIsXG4gICAgICAgIG1vZHVsZU5hbWUsXG4gICAgICAgIGZvbGRlclxuICAgICAgKTtcbiAgICAgIGNvbnN0IGlkeCA9IFtcbiAgICAgICAgcGF0aC5qb2luKGZvbGRlclBhdGgsIFwiaW5kZXgudHNcIiksXG4gICAgICAgIHBhdGguam9pbihmb2xkZXJQYXRoLCBcImluZGV4LmpzXCIpLFxuICAgICAgICBwYXRoLmpvaW4oZm9sZGVyUGF0aCwgXCJpbmRleC5janNcIiksXG4gICAgICBdLmZpbmQoZnMuZXhpc3RzU3luYyk7XG4gICAgICBpZiAoIWlkeCkgY29udGludWU7XG4gICAgICBjb25zdCB0ZXh0ID0gZnMucmVhZEZpbGVTeW5jKGlkeCwgXCJ1dGY4XCIpO1xuICAgICAgY29uc3QgcmUgPSAvaWRcXHMqOlxccypbJ1wiYCBdPyhbXidcImAgLH1dKykvZztcbiAgICAgIGxldCBtOiBSZWdFeHBFeGVjQXJyYXkgfCBudWxsO1xuICAgICAgd2hpbGUgKChtID0gcmUuZXhlYyh0ZXh0KSkgIT09IG51bGwpIHtcbiAgICAgICAgY29uc3QgaWQgPSBtWzFdO1xuICAgICAgICBpZiAoIWlkKSBjb250aW51ZTtcbiAgICAgICAgaWYgKCFpZE1hcC5oYXMoaWQpKSBpZE1hcC5zZXQoaWQsIFtdKTtcbiAgICAgICAgaWRNYXAuZ2V0KGlkKSEucHVzaChtb2R1bGVOYW1lKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IFtpZCwgbW9kc10gb2YgaWRNYXAuZW50cmllcygpKSB7XG4gICAgaWYgKG1vZHMubGVuZ3RoID4gMSkge1xuICAgICAgaXNzdWVzLnB1c2goe1xuICAgICAgICB0eXBlOiBcImR1cGxpY2F0ZS1pZFwiLFxuICAgICAgICBkZXRhaWw6IGBEdXBsaWNhdGUgaWQgJHtpZH0gaW4gbW9kdWxlczogJHttb2RzLmpvaW4oXCIsIFwiKX1gLFxuICAgICAgICBtb2R1bGVzOiBtb2RzLFxuICAgICAgICBzZXZlcml0eTogXCJ3YXJuaW5nXCIsXG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBjb25zdCBoYXNFcnJvcnMgPSBpc3N1ZXMuc29tZSgoaSkgPT4gaS5zZXZlcml0eSA9PT0gXCJlcnJvclwiKTtcbiAgcmV0dXJuIHsgaXNzdWVzLCBoYXNFcnJvcnMgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydE1vZHVsZVNjYWZmb2xkaW5nKHdvcmtzcGFjZVJvb3QgPSBwcm9jZXNzLmN3ZCgpKSB7XG4gIGNvbnN0IHsgaXNzdWVzLCBoYXNFcnJvcnMgfSA9IHZhbGlkYXRlTW9kdWxlU2NhZmZvbGRpbmcod29ya3NwYWNlUm9vdCk7XG4gIGlmIChoYXNFcnJvcnMpIHtcbiAgICBjb25zdCBkZXRhaWxzID0gaXNzdWVzXG4gICAgICAuZmlsdGVyKChpKSA9PiBpLnNldmVyaXR5ID09PSBcImVycm9yXCIpXG4gICAgICAubWFwKChpKSA9PiBgLSBbJHtpLm1vZHVsZSB8fCBcIj9cIn1dICR7aS5kZXRhaWx9YClcbiAgICAgIC5qb2luKFwiXFxuXCIpO1xuICAgIGNvbnN0IGVyciA9IG5ldyBFcnJvcihgTW9kdWxlIHZhbGlkYXRpb24gZmFpbGVkOlxcbiR7ZGV0YWlsc31gKTtcbiAgICAvLyBhdHRhY2ggZGV0YWlscyBmb3IgY2FsbGVyc1xuICAgIChlcnIgYXMgdW5rbm93biBhcyB7IGlzc3Vlcz86IFZhbGlkYXRpb25Jc3N1ZVtdIH0pLmlzc3VlcyA9IGlzc3VlcztcbiAgICB0aHJvdyBlcnI7XG4gIH1cbiAgcmV0dXJuIGlzc3Vlcztcbn1cblxuIl19
@@ -0,0 +1,14 @@
1
+ type ValidationIssue = {
2
+ type: string;
3
+ module?: string;
4
+ detail: string;
5
+ severity: "error" | "warning" | "info";
6
+ modules?: string[];
7
+ };
8
+ export declare function listModuleDirectories(workspaceRoot: string): string[];
9
+ export declare function validateModuleScaffolding(workspaceRoot?: string): {
10
+ issues: ValidationIssue[];
11
+ hasErrors: boolean;
12
+ };
13
+ export declare function assertModuleScaffolding(workspaceRoot?: string): ValidationIssue[];
14
+ export {};
package/lib/utils.cjs CHANGED
@@ -32,6 +32,9 @@ var __importStar = (this && this.__importStar) || (function () {
32
32
  return result;
33
33
  };
34
34
  })();
35
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
36
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
37
+ };
35
38
  var __importDefault = (this && this.__importDefault) || function (mod) {
36
39
  return (mod && mod.__esModule) ? mod : { "default": mod };
37
40
  };
@@ -122,4 +125,5 @@ class McpUtils {
122
125
  }
123
126
  }
124
127
  exports.McpUtils = McpUtils;
125
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMEJBQTBCO0FBQzFCLGdEQUF3QjtBQUN4Qiw0Q0FBb0I7QUFHcEI7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQWEsUUFBUTtJQUNuQjs7Ozs7O09BTUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFZO1FBQ3BDLElBQUksQ0FBQztZQUNILE9BQU8sUUFBUSxDQUFDLGVBQWUsb0JBQVEsSUFBSSx3Q0FBRSxDQUFDO1FBQ2hELENBQUM7UUFBQyxPQUFPLENBQVUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQ2IsdUJBQXVCLElBQUksS0FBSyxDQUFDLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDckUsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBSSxhQUF5QjtRQUN2RCxtRUFBbUU7UUFDbkUsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUN2QixDQUFDLENBQVUsRUFBRSxFQUFFLENBQUMsQ0FBRSxDQUFvQixDQUFDLE9BQU8sSUFBSSxDQUFDLENBQU0sQ0FDMUQsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7OztPQU9HO0lBQ0ssTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFnQjtRQUN4QyxJQUFJLENBQUM7WUFDSCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQ2YsWUFBRSxDQUFDLFlBQVksQ0FBQyxjQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxjQUFjLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FDN0QsQ0FBQztRQUNKLENBQUM7UUFBQyxPQUFPLENBQVUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsK0JBQStCLFFBQVEsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ25FLENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsTUFBTSxDQUFDLGNBQWMsQ0FBQyxRQUFnQjtRQUNwQyxPQUFPLFFBQVEsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFXLENBQUM7SUFDNUQsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILE1BQU0sQ0FBQyxXQUFXLENBQUMsUUFBZ0I7UUFDakMsTUFBTSxJQUFJLEdBQUksUUFBUSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLENBQVksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUUsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMvQixDQUFDO0NBQ0Y7QUExRUQsNEJBMEVDIiwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCI7XG5pbXBvcnQgZnMgZnJvbSBcImZzXCI7XG5pbXBvcnQgeyBNY3BNb2R1bGUgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBVdGlsaXR5IGNsYXNzIGZvciBDTEkgb3BlcmF0aW9uc1xuICogQHN1bW1hcnkgQSBzdGF0aWMgdXRpbGl0eSBjbGFzcyB0aGF0IHByb3ZpZGVzIG1ldGhvZHMgZm9yIGxvYWRpbmcgbW9kdWxlcywgcmV0cmlldmluZyBwYWNrYWdlIGluZm9ybWF0aW9uLCBhbmQgaW5pdGlhbGl6aW5nIENMSSBjb21tYW5kc1xuICpcbiAqIEBleGFtcGxlXG4gKiAvLyBJbml0aWFsaXplIGEgQ29tbWFuZCBvYmplY3Qgd2l0aCBwYWNrYWdlIGluZm9ybWF0aW9uXG4gKiBjb25zdCBjb21tYW5kID0gbmV3IENvbW1hbmQoKTtcbiAqIENMSVV0aWxzLmluaXRpYWxpemUoY29tbWFuZCwgJy4vcGF0aC90by9wYWNrYWdlJyk7XG4gKlxuICogLy8gTG9hZCBhIENMSSBtb2R1bGUgZnJvbSBhIGZpbGVcbiAqIGNvbnN0IG1vZHVsZSA9IGF3YWl0IENMSVV0aWxzLmxvYWRGcm9tRmlsZSgnLi9wYXRoL3RvL2NsaS1tb2R1bGUuanMnKTtcbiAqXG4gKiBAY2xhc3MgTWNwVXRpbHNcbiAqL1xuZXhwb3J0IGNsYXNzIE1jcFV0aWxzIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBEeW5hbWljYWxseSBpbXBvcnRzIGEgbW9kdWxlIGZpbGVcbiAgICogQHN1bW1hcnkgTG9hZHMgYSBKYXZhU2NyaXB0IGZpbGUgYW5kIHJldHVybnMgaXQgYXMgYSBDbGlNb2R1bGUsIGhhbmRsaW5nIGJvdGggRVNNIGFuZCBDb21tb25KUyBmb3JtYXRzXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwYXRoIFRoZSBmaWxlIHBhdGggdG8gdGhlIG1vZHVsZSB0byBsb2FkXG4gICAqIEByZXR1cm4ge1Byb21pc2U8TWNwTW9kdWxlPn0gQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGxvYWRlZCBDbGlNb2R1bGVcbiAgICovXG4gIHN0YXRpYyBhc3luYyBsb2FkRnJvbUZpbGUocGF0aDogc3RyaW5nKTogUHJvbWlzZTxNY3BNb2R1bGU+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIE1jcFV0aWxzLm5vcm1hbGl6ZUltcG9ydChpbXBvcnQocGF0aCkpO1xuICAgIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYEZhaWxlZCB0byBsb2FkIGZyb20gJHtwYXRofTogJHtlIGluc3RhbmNlb2YgRXJyb3IgPyBlLm1lc3NhZ2UgOiBlfWBcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBOb3JtYWxpemVzIG1vZHVsZSBpbXBvcnRzIHRvIGhhbmRsZSBib3RoIEVTTSBhbmQgQ29tbW9uSlMgZm9ybWF0c1xuICAgKiBAc3VtbWFyeSBQcm9wZXJseSBpbXBvcnRzIEphdmFTY3JpcHQgZmlsZXMgcmVnYXJkbGVzcyBvZiB0aGVpciBtb2R1bGUgZm9ybWF0IGJ5IGhhbmRsaW5nIHRoZSBFU00gd3JhcHBlciBmb3IgQ29tbW9uSlMgbW9kdWxlc1xuICAgKlxuICAgKiBAdGVtcGxhdGUgVCBUaGUgdHlwZSBvZiB0aGUgaW1wb3J0ZWQgbW9kdWxlXG4gICAqIEBwYXJhbSB7UHJvbWlzZTxUPn0gaW1wb3J0UHJvbWlzZSBUaGUgcHJvbWlzZSByZXR1cm5lZCBieSB0aGUgZHluYW1pYyBpbXBvcnRcbiAgICogQHJldHVybiB7UHJvbWlzZTxUPn0gQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIG5vcm1hbGl6ZWQgbW9kdWxlXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBzdGF0aWMgYXN5bmMgbm9ybWFsaXplSW1wb3J0PFQ+KGltcG9ydFByb21pc2U6IFByb21pc2U8VD4pOiBQcm9taXNlPFQ+IHtcbiAgICAvLyBDb21tb25KUydzIGBtb2R1bGUuZXhwb3J0c2AgaXMgd3JhcHBlZCBhcyBgZGVmYXVsdGAgaW4gRVNNb2R1bGUuXG4gICAgcmV0dXJuIGltcG9ydFByb21pc2UudGhlbihcbiAgICAgIChtOiB1bmtub3duKSA9PiAoKG0gYXMgeyBkZWZhdWx0OiBUIH0pLmRlZmF1bHQgfHwgbSkgYXMgVFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFJldHJpZXZlcyBhbmQgcGFyc2VzIHRoZSBwYWNrYWdlLmpzb24gZmlsZVxuICAgKiBAc3VtbWFyeSBSZWFkcyB0aGUgcGFja2FnZS5qc29uIGZpbGUgZnJvbSB0aGUgc3BlY2lmaWVkIHBhdGggYW5kIHBhcnNlcyBpdCBpbnRvIGEgSmF2YVNjcmlwdCBvYmplY3RcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7UmVjb3JkPHN0cmluZywgdW5rbm93bj59IFRoZSBwYXJzZWQgcGFja2FnZS5qc29uIGNvbnRlbnQgYXMgYW4gb2JqZWN0XG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBwcml2YXRlIHN0YXRpYyBnZXRQYWNrYWdlKGJhc2VQYXRoOiBzdHJpbmcpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBKU09OLnBhcnNlKFxuICAgICAgICBmcy5yZWFkRmlsZVN5bmMocGF0aC5qb2luKGJhc2VQYXRoLCBcInBhY2thZ2UuanNvblwiKSwgXCJ1dGY4XCIpXG4gICAgICApO1xuICAgIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5hYmxlIHRvIHJlYWQgdmVyc2lvbiBmcm9tICR7YmFzZVBhdGh9OiAke2V9YCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZXR1cm5zIHRoZSB2ZXJzaW9uIGZyb20gcGFja2FnZS5qc29uXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgdmVyc2lvbiBmaWVsZCBmcm9tIHRoZSBwYWNrYWdlLmpzb24gZmlsZSBhdCB0aGUgc3BlY2lmaWVkIHBhdGhcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7c3RyaW5nfSBUaGUgcGFja2FnZSB2ZXJzaW9uIHN0cmluZ1xuICAgKi9cbiAgc3RhdGljIHBhY2thZ2VWZXJzaW9uKGJhc2VQYXRoOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBNY3BVdGlscy5nZXRQYWNrYWdlKGJhc2VQYXRoKVtcInZlcnNpb25cIl0gYXMgc3RyaW5nO1xuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZXR1cm5zIHRoZSBuYW1lIGZyb20gcGFja2FnZS5qc29uXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgbmFtZSBmaWVsZCBmcm9tIHRoZSBwYWNrYWdlLmpzb24gZmlsZSBhdCB0aGUgc3BlY2lmaWVkIHBhdGggYW5kIGV4dHJhY3RzIHRoZSBwYWNrYWdlIG5hbWUgd2l0aG91dCB0aGUgc2NvcGVcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7c3RyaW5nfSBUaGUgcGFja2FnZSBuYW1lIHdpdGhvdXQgdGhlIHNjb3BlIChlLmcuLCBcImNsaVwiIGZyb20gXCJAZGVjYWYtdHMvY2xpXCIpXG4gICAqL1xuICBzdGF0aWMgcGFja2FnZU5hbWUoYmFzZVBhdGg6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3QgbmFtZSA9IChNY3BVdGlscy5nZXRQYWNrYWdlKGJhc2VQYXRoKVtcIm5hbWVcIl0gYXMgc3RyaW5nKS5zcGxpdChcIi9cIik7XG4gICAgcmV0dXJuIG5hbWVbbmFtZS5sZW5ndGggLSAxXTtcbiAgfVxufVxuIl19
128
+ __exportStar(require("./utils/modulePaths.cjs"), exports);
129
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMEJBQTBCO0FBQzFCLGdEQUF3QjtBQUN4Qiw0Q0FBb0I7QUFHcEI7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQWEsUUFBUTtJQUNuQjs7Ozs7O09BTUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxJQUFZO1FBQ3BDLElBQUksQ0FBQztZQUNILE9BQU8sUUFBUSxDQUFDLGVBQWUsb0JBQVEsSUFBSSx3Q0FBRSxDQUFDO1FBQ2hELENBQUM7UUFBQyxPQUFPLENBQVUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQ2IsdUJBQXVCLElBQUksS0FBSyxDQUFDLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDckUsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCxNQUFNLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBSSxhQUF5QjtRQUN2RCxtRUFBbUU7UUFDbkUsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUN2QixDQUFDLENBQVUsRUFBRSxFQUFFLENBQUMsQ0FBRSxDQUFvQixDQUFDLE9BQU8sSUFBSSxDQUFDLENBQU0sQ0FDMUQsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7OztPQU9HO0lBQ0ssTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFnQjtRQUN4QyxJQUFJLENBQUM7WUFDSCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQ2YsWUFBRSxDQUFDLFlBQVksQ0FBQyxjQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxjQUFjLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FDN0QsQ0FBQztRQUNKLENBQUM7UUFBQyxPQUFPLENBQVUsRUFBRSxDQUFDO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsK0JBQStCLFFBQVEsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ25FLENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsTUFBTSxDQUFDLGNBQWMsQ0FBQyxRQUFnQjtRQUNwQyxPQUFPLFFBQVEsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFXLENBQUM7SUFDNUQsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILE1BQU0sQ0FBQyxXQUFXLENBQUMsUUFBZ0I7UUFDakMsTUFBTSxJQUFJLEdBQUksUUFBUSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLENBQVksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUUsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMvQixDQUFDO0NBQ0Y7QUExRUQsNEJBMEVDO0FBRUQsMERBQW9DIiwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cbmltcG9ydCBwYXRoIGZyb20gXCJwYXRoXCI7XG5pbXBvcnQgZnMgZnJvbSBcImZzXCI7XG5pbXBvcnQgeyBNY3BNb2R1bGUgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBVdGlsaXR5IGNsYXNzIGZvciBDTEkgb3BlcmF0aW9uc1xuICogQHN1bW1hcnkgQSBzdGF0aWMgdXRpbGl0eSBjbGFzcyB0aGF0IHByb3ZpZGVzIG1ldGhvZHMgZm9yIGxvYWRpbmcgbW9kdWxlcywgcmV0cmlldmluZyBwYWNrYWdlIGluZm9ybWF0aW9uLCBhbmQgaW5pdGlhbGl6aW5nIENMSSBjb21tYW5kc1xuICpcbiAqIEBleGFtcGxlXG4gKiAvLyBJbml0aWFsaXplIGEgQ29tbWFuZCBvYmplY3Qgd2l0aCBwYWNrYWdlIGluZm9ybWF0aW9uXG4gKiBjb25zdCBjb21tYW5kID0gbmV3IENvbW1hbmQoKTtcbiAqIENMSVV0aWxzLmluaXRpYWxpemUoY29tbWFuZCwgJy4vcGF0aC90by9wYWNrYWdlJyk7XG4gKlxuICogLy8gTG9hZCBhIENMSSBtb2R1bGUgZnJvbSBhIGZpbGVcbiAqIGNvbnN0IG1vZHVsZSA9IGF3YWl0IENMSVV0aWxzLmxvYWRGcm9tRmlsZSgnLi9wYXRoL3RvL2NsaS1tb2R1bGUuanMnKTtcbiAqXG4gKiBAY2xhc3MgTWNwVXRpbHNcbiAqL1xuZXhwb3J0IGNsYXNzIE1jcFV0aWxzIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBEeW5hbWljYWxseSBpbXBvcnRzIGEgbW9kdWxlIGZpbGVcbiAgICogQHN1bW1hcnkgTG9hZHMgYSBKYXZhU2NyaXB0IGZpbGUgYW5kIHJldHVybnMgaXQgYXMgYSBDbGlNb2R1bGUsIGhhbmRsaW5nIGJvdGggRVNNIGFuZCBDb21tb25KUyBmb3JtYXRzXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwYXRoIFRoZSBmaWxlIHBhdGggdG8gdGhlIG1vZHVsZSB0byBsb2FkXG4gICAqIEByZXR1cm4ge1Byb21pc2U8TWNwTW9kdWxlPn0gQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGxvYWRlZCBDbGlNb2R1bGVcbiAgICovXG4gIHN0YXRpYyBhc3luYyBsb2FkRnJvbUZpbGUocGF0aDogc3RyaW5nKTogUHJvbWlzZTxNY3BNb2R1bGU+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIE1jcFV0aWxzLm5vcm1hbGl6ZUltcG9ydChpbXBvcnQocGF0aCkpO1xuICAgIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYEZhaWxlZCB0byBsb2FkIGZyb20gJHtwYXRofTogJHtlIGluc3RhbmNlb2YgRXJyb3IgPyBlLm1lc3NhZ2UgOiBlfWBcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBOb3JtYWxpemVzIG1vZHVsZSBpbXBvcnRzIHRvIGhhbmRsZSBib3RoIEVTTSBhbmQgQ29tbW9uSlMgZm9ybWF0c1xuICAgKiBAc3VtbWFyeSBQcm9wZXJseSBpbXBvcnRzIEphdmFTY3JpcHQgZmlsZXMgcmVnYXJkbGVzcyBvZiB0aGVpciBtb2R1bGUgZm9ybWF0IGJ5IGhhbmRsaW5nIHRoZSBFU00gd3JhcHBlciBmb3IgQ29tbW9uSlMgbW9kdWxlc1xuICAgKlxuICAgKiBAdGVtcGxhdGUgVCBUaGUgdHlwZSBvZiB0aGUgaW1wb3J0ZWQgbW9kdWxlXG4gICAqIEBwYXJhbSB7UHJvbWlzZTxUPn0gaW1wb3J0UHJvbWlzZSBUaGUgcHJvbWlzZSByZXR1cm5lZCBieSB0aGUgZHluYW1pYyBpbXBvcnRcbiAgICogQHJldHVybiB7UHJvbWlzZTxUPn0gQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIG5vcm1hbGl6ZWQgbW9kdWxlXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBzdGF0aWMgYXN5bmMgbm9ybWFsaXplSW1wb3J0PFQ+KGltcG9ydFByb21pc2U6IFByb21pc2U8VD4pOiBQcm9taXNlPFQ+IHtcbiAgICAvLyBDb21tb25KUydzIGBtb2R1bGUuZXhwb3J0c2AgaXMgd3JhcHBlZCBhcyBgZGVmYXVsdGAgaW4gRVNNb2R1bGUuXG4gICAgcmV0dXJuIGltcG9ydFByb21pc2UudGhlbihcbiAgICAgIChtOiB1bmtub3duKSA9PiAoKG0gYXMgeyBkZWZhdWx0OiBUIH0pLmRlZmF1bHQgfHwgbSkgYXMgVFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFJldHJpZXZlcyBhbmQgcGFyc2VzIHRoZSBwYWNrYWdlLmpzb24gZmlsZVxuICAgKiBAc3VtbWFyeSBSZWFkcyB0aGUgcGFja2FnZS5qc29uIGZpbGUgZnJvbSB0aGUgc3BlY2lmaWVkIHBhdGggYW5kIHBhcnNlcyBpdCBpbnRvIGEgSmF2YVNjcmlwdCBvYmplY3RcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7UmVjb3JkPHN0cmluZywgdW5rbm93bj59IFRoZSBwYXJzZWQgcGFja2FnZS5qc29uIGNvbnRlbnQgYXMgYW4gb2JqZWN0XG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBwcml2YXRlIHN0YXRpYyBnZXRQYWNrYWdlKGJhc2VQYXRoOiBzdHJpbmcpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBKU09OLnBhcnNlKFxuICAgICAgICBmcy5yZWFkRmlsZVN5bmMocGF0aC5qb2luKGJhc2VQYXRoLCBcInBhY2thZ2UuanNvblwiKSwgXCJ1dGY4XCIpXG4gICAgICApO1xuICAgIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5hYmxlIHRvIHJlYWQgdmVyc2lvbiBmcm9tICR7YmFzZVBhdGh9OiAke2V9YCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZXR1cm5zIHRoZSB2ZXJzaW9uIGZyb20gcGFja2FnZS5qc29uXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgdmVyc2lvbiBmaWVsZCBmcm9tIHRoZSBwYWNrYWdlLmpzb24gZmlsZSBhdCB0aGUgc3BlY2lmaWVkIHBhdGhcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7c3RyaW5nfSBUaGUgcGFja2FnZSB2ZXJzaW9uIHN0cmluZ1xuICAgKi9cbiAgc3RhdGljIHBhY2thZ2VWZXJzaW9uKGJhc2VQYXRoOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBNY3BVdGlscy5nZXRQYWNrYWdlKGJhc2VQYXRoKVtcInZlcnNpb25cIl0gYXMgc3RyaW5nO1xuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZXR1cm5zIHRoZSBuYW1lIGZyb20gcGFja2FnZS5qc29uXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgbmFtZSBmaWVsZCBmcm9tIHRoZSBwYWNrYWdlLmpzb24gZmlsZSBhdCB0aGUgc3BlY2lmaWVkIHBhdGggYW5kIGV4dHJhY3RzIHRoZSBwYWNrYWdlIG5hbWUgd2l0aG91dCB0aGUgc2NvcGVcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGJhc2VQYXRoIFRoZSBiYXNlIHBhdGggd2hlcmUgdGhlIHBhY2thZ2UuanNvbiBmaWxlIGlzIGxvY2F0ZWRcbiAgICogQHJldHVybiB7c3RyaW5nfSBUaGUgcGFja2FnZSBuYW1lIHdpdGhvdXQgdGhlIHNjb3BlIChlLmcuLCBcImNsaVwiIGZyb20gXCJAZGVjYWYtdHMvY2xpXCIpXG4gICAqL1xuICBzdGF0aWMgcGFja2FnZU5hbWUoYmFzZVBhdGg6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgY29uc3QgbmFtZSA9IChNY3BVdGlscy5nZXRQYWNrYWdlKGJhc2VQYXRoKVtcIm5hbWVcIl0gYXMgc3RyaW5nKS5zcGxpdChcIi9cIik7XG4gICAgcmV0dXJuIG5hbWVbbmFtZS5sZW5ndGggLSAxXTtcbiAgfVxufVxuXG5leHBvcnQgKiBmcm9tIFwiLi91dGlscy9tb2R1bGVQYXRoc1wiO1xuIl19
package/lib/utils.d.ts CHANGED
@@ -58,3 +58,4 @@ export declare class McpUtils {
58
58
  */
59
59
  static packageName(basePath: string): string;
60
60
  }
61
+ export * from "./utils/modulePaths";
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@decaf-ts/mcp-server",
3
- "version": "0.0.4",
4
- "description": "template for ts projects",
3
+ "version": "0.2.0",
4
+ "description": "mcp server for code assistance of decaf-ts projects",
5
5
  "type": "module",
6
6
  "bin": {
7
7
  "decaf-mcp": "./lib/bin/cli.cjs"
@@ -13,9 +13,10 @@
13
13
  "main": "lib/decaf-mcp.cjs",
14
14
  "types": "lib/index.d.ts",
15
15
  "scripts": {
16
- "start": "node dist/fastmcp-server.js",
16
+ "start": "node lib/bin/cli.cjs",
17
17
  "dev": "tsx watch fastmcp-server.ts",
18
18
  "do-install": "NPM_TOKEN=$(cat .npmtoken) npm install",
19
+ "update-dependencies": "PREFIX=\"decaf-ts\"; npm ls | grep \"$PREFIX\" | awk -F/ '{print $NF}' | sed 's/@.*//' | xargs -I package npm update @\"$PREFIX\"/package",
19
20
  "update-scripts": "node ./bin/update-scripts.cjs",
20
21
  "on-first-run": "node ./bin/update-scripts.cjs --boot",
21
22
  "set-git-auth": "git config url.\"https://api:$(cat .token)@github.com/\".insteadOf \"https://github.com/\" && git config url.\"https://ssh:$(cat .token)@github.com/\".insteadOf \"ssh://git@github.com/\" && git config url.\"https://git:$(cat .token)@github.com/\".insteadOf \"git@github.com:\"",
@@ -30,15 +31,19 @@
30
31
  "test:all": "jest --testPathPattern=\"/tests\" --passWithNoTests --detectOpenHandles",
31
32
  "test:circular": "dpdm -T --no-warning --no-tree ./src/index.ts",
32
33
  "coverage": "rimraf ./workdocs/reports/data/*.json && npm run test:all -- --coverage --config=./workdocs/reports/jest.coverage.config.ts",
34
+ "validate:modules": "node ./src/bin/validate-modules.cjs",
35
+ "validate-modules": "npm run validate:modules",
33
36
  "lint": "eslint .",
34
37
  "lint-fix": "eslint --fix .",
35
38
  "prepare-pr": "npm run lint-fix && npm run build:prod && npm run coverage && npm run docs",
36
- "prepare-release": "npm run lint-fix && npm run build:prod && npm run coverage && npm run docs",
39
+ "prepare-release": "npm run build:prod && npm run coverage",
37
40
  "release": "./bin/tag-release.sh",
38
41
  "clean-publish": "npx clean-publish",
39
42
  "drawings": "for FILE in workdocs/drawings/*.drawio; do echo \"converting $FILE to image...\" && docker run --rm -v $(pwd):/data rlespinasse/drawio-export --format png $FILE; done && cp -rf workdocs/drawings/export/* workdocs/resources/",
40
43
  "uml": "cd workdocs/uml && for FILE in ./*.puml; do docker run --rm -v $(pwd):/work -w /work miy4/plantuml -DPLANTUML_LIMIT_SIZE=8192 -tpng $FILE; done && cd ../.. && cp -fr workdocs/uml/*.png workdocs/resources/",
41
44
  "docs": "npx rimraf ./docs && mkdir docs && node ./bin/build-scripts.cjs --docs",
45
+ "scaffold-module": "node ./src/bin/scaffold-module.cjs",
46
+ "check-aggregation": "node ./src/bin/check-aggregate.cjs",
42
47
  "publish-docs": "docker run -it --rm --user $(id -u):$(id -g) -v \"$(pwd)/workdocs/confluence:/content\" -e ATLASSIAN_API_TOKEN=$(cat .confluence-token) ghcr.io/markdown-confluence/publish:latest",
43
48
  "docker:login": "docker login ghcr.io -u $(cat .dockeruser) -p $(cat .dockertoken)",
44
49
  "docker:build": "npm run docker:build-base",
@@ -55,7 +60,7 @@
55
60
  },
56
61
  "repository": {
57
62
  "type": "git",
58
- "url": "git+https://github.com/decaf-ts/ts-workspace.git"
63
+ "url": "git+https://github.com/decaf-ts/mc-server.git"
59
64
  },
60
65
  "engines": {
61
66
  "node": ">=20.0.0",
@@ -88,9 +93,9 @@
88
93
  ],
89
94
  "author": "Tiago Venceslau and Contributors",
90
95
  "bugs": {
91
- "url": "https://github.com/decaf-ts/ts-workspace/issues"
96
+ "url": "https://github.com/decaf-ts/mcp-server/issues"
92
97
  },
93
- "homepage": "https://github.com/decaf-ts/ts-workspace#readme",
98
+ "homepage": "https://github.com/decaf-ts/mcp-server#readme",
94
99
  "devDependencies": {
95
100
  "@decaf-ts/utils": "latest",
96
101
  "@eslint/js": "^9.25.1",
@@ -132,11 +137,12 @@
132
137
  "@decaf-ts/logging": "latest",
133
138
  "diff": "^7.0.0",
134
139
  "ts-morph": "^21.0.0",
135
- "typescript": "^5.6.3",
136
- "zod": "^3.25.76"
140
+ "typescript": "^5.6.3"
137
141
  },
138
- "license": "MIT OR AGPL-3.0-only",
142
+ "license": "AGPL-3.0-only",
139
143
  "dependencies": {
140
- "fastmcp": "^3.20.0"
144
+ "better-docs": "^2.7.3",
145
+ "fastmcp": "^3.20.0",
146
+ "taffydb": "^2.7.3"
141
147
  }
142
148
  }