vitek-plugin 0.2.1-beta → 0.2.2-beta

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 (258) hide show
  1. package/README.md +1 -1
  2. package/dist/adapters/dispatch/http-webhook.d.ts +10 -0
  3. package/dist/adapters/dispatch/http-webhook.d.ts.map +1 -0
  4. package/dist/adapters/dispatch/http-webhook.js +38 -0
  5. package/dist/adapters/node/console-structured-request-logger.d.ts +6 -0
  6. package/dist/adapters/node/console-structured-request-logger.d.ts.map +1 -0
  7. package/dist/adapters/node/console-structured-request-logger.js +31 -0
  8. package/dist/build/build-api-bundle.d.ts.map +1 -1
  9. package/dist/build/build-api-bundle.js +11 -0
  10. package/dist/build/build-sockets-bundle.d.ts.map +1 -1
  11. package/dist/build/build-sockets-bundle.js +11 -0
  12. package/dist/cli/contract.d.ts +11 -0
  13. package/dist/cli/contract.d.ts.map +1 -0
  14. package/dist/cli/contract.js +143 -0
  15. package/dist/cli/doctor.d.ts +2 -0
  16. package/dist/cli/doctor.d.ts.map +1 -0
  17. package/dist/cli/doctor.js +70 -0
  18. package/dist/cli/generate.d.ts +2 -0
  19. package/dist/cli/generate.d.ts.map +1 -0
  20. package/dist/cli/generate.js +56 -0
  21. package/dist/cli/mcp-docs.d.ts +2 -0
  22. package/dist/cli/mcp-docs.d.ts.map +1 -0
  23. package/dist/cli/mcp-docs.js +4 -0
  24. package/dist/cli/mcp-project-write-tools.d.ts +4 -0
  25. package/dist/cli/mcp-project-write-tools.d.ts.map +1 -0
  26. package/dist/cli/mcp-project-write-tools.js +64 -0
  27. package/dist/cli/schedule.d.ts +2 -0
  28. package/dist/cli/schedule.d.ts.map +1 -0
  29. package/dist/cli/schedule.js +66 -0
  30. package/dist/core/contract/compare-asyncapi.d.ts +3 -0
  31. package/dist/core/contract/compare-asyncapi.d.ts.map +1 -0
  32. package/dist/core/contract/compare-asyncapi.js +45 -0
  33. package/dist/core/contract/compare-openapi.d.ts +3 -0
  34. package/dist/core/contract/compare-openapi.d.ts.map +1 -0
  35. package/dist/core/contract/compare-openapi.js +116 -0
  36. package/dist/core/contract/http-methods.d.ts +2 -0
  37. package/dist/core/contract/http-methods.d.ts.map +1 -0
  38. package/dist/core/contract/http-methods.js +2 -0
  39. package/dist/core/contract/index.d.ts +9 -0
  40. package/dist/core/contract/index.d.ts.map +1 -0
  41. package/dist/core/contract/index.js +7 -0
  42. package/dist/core/contract/project-specs.d.ts +12 -0
  43. package/dist/core/contract/project-specs.d.ts.map +1 -0
  44. package/dist/core/contract/project-specs.js +27 -0
  45. package/dist/core/contract/sort-json.d.ts +2 -0
  46. package/dist/core/contract/sort-json.d.ts.map +1 -0
  47. package/dist/core/contract/sort-json.js +14 -0
  48. package/dist/core/contract/types.d.ts +7 -0
  49. package/dist/core/contract/types.d.ts.map +1 -0
  50. package/dist/core/contract/types.js +1 -0
  51. package/dist/core/dispatch/dispatchers.d.ts +4 -0
  52. package/dist/core/dispatch/dispatchers.d.ts.map +1 -0
  53. package/dist/core/dispatch/dispatchers.js +16 -0
  54. package/dist/core/dispatch/emit-safe.d.ts +3 -0
  55. package/dist/core/dispatch/emit-safe.d.ts.map +1 -0
  56. package/dist/core/dispatch/emit-safe.js +10 -0
  57. package/dist/core/dispatch/index.d.ts +4 -0
  58. package/dist/core/dispatch/index.d.ts.map +1 -0
  59. package/dist/core/dispatch/index.js +2 -0
  60. package/dist/core/dispatch/types.d.ts +22 -0
  61. package/dist/core/dispatch/types.d.ts.map +1 -0
  62. package/dist/core/dispatch/types.js +1 -0
  63. package/dist/core/doctor/index.d.ts +3 -0
  64. package/dist/core/doctor/index.d.ts.map +1 -0
  65. package/dist/core/doctor/index.js +1 -0
  66. package/dist/core/doctor/report.d.ts +4 -0
  67. package/dist/core/doctor/report.d.ts.map +1 -0
  68. package/dist/core/doctor/report.js +166 -0
  69. package/dist/core/doctor/scan.d.ts +3 -0
  70. package/dist/core/doctor/scan.d.ts.map +1 -0
  71. package/dist/core/doctor/scan.js +23 -0
  72. package/dist/core/doctor/types.d.ts +12 -0
  73. package/dist/core/doctor/types.d.ts.map +1 -0
  74. package/dist/core/doctor/types.js +1 -0
  75. package/dist/core/events/event-bus.d.ts +8 -0
  76. package/dist/core/events/event-bus.d.ts.map +1 -0
  77. package/dist/core/events/event-bus.js +26 -0
  78. package/dist/core/events/index.d.ts +3 -0
  79. package/dist/core/events/index.d.ts.map +1 -0
  80. package/dist/core/events/index.js +1 -0
  81. package/dist/core/generators/adapters/drizzle.d.ts +3 -0
  82. package/dist/core/generators/adapters/drizzle.d.ts.map +1 -0
  83. package/dist/core/generators/adapters/drizzle.js +26 -0
  84. package/dist/core/generators/adapters/prisma.d.ts +3 -0
  85. package/dist/core/generators/adapters/prisma.d.ts.map +1 -0
  86. package/dist/core/generators/adapters/prisma.js +136 -0
  87. package/dist/core/generators/adapters/sql.d.ts +3 -0
  88. package/dist/core/generators/adapters/sql.d.ts.map +1 -0
  89. package/dist/core/generators/adapters/sql.js +26 -0
  90. package/dist/core/generators/generate-crud.d.ts +8 -0
  91. package/dist/core/generators/generate-crud.d.ts.map +1 -0
  92. package/dist/core/generators/generate-crud.js +17 -0
  93. package/dist/core/generators/index.d.ts +3 -0
  94. package/dist/core/generators/index.d.ts.map +1 -0
  95. package/dist/core/generators/index.js +1 -0
  96. package/dist/core/generators/types.d.ts +16 -0
  97. package/dist/core/generators/types.d.ts.map +1 -0
  98. package/dist/core/generators/types.js +1 -0
  99. package/dist/core/generators/utils.d.ts +3 -0
  100. package/dist/core/generators/utils.d.ts.map +1 -0
  101. package/dist/core/generators/utils.js +10 -0
  102. package/dist/core/observability/with-span.d.ts +5 -0
  103. package/dist/core/observability/with-span.d.ts.map +1 -0
  104. package/dist/core/observability/with-span.js +7 -0
  105. package/dist/core/scheduler/define-schedule.d.ts +3 -0
  106. package/dist/core/scheduler/define-schedule.d.ts.map +1 -0
  107. package/dist/core/scheduler/define-schedule.js +3 -0
  108. package/dist/core/scheduler/in-memory-lock.d.ts +6 -0
  109. package/dist/core/scheduler/in-memory-lock.d.ts.map +1 -0
  110. package/dist/core/scheduler/in-memory-lock.js +12 -0
  111. package/dist/core/scheduler/index.d.ts +5 -0
  112. package/dist/core/scheduler/index.d.ts.map +1 -0
  113. package/dist/core/scheduler/index.js +3 -0
  114. package/dist/core/scheduler/runner.d.ts +6 -0
  115. package/dist/core/scheduler/runner.d.ts.map +1 -0
  116. package/dist/core/scheduler/runner.js +37 -0
  117. package/dist/core/scheduler/types.d.ts +21 -0
  118. package/dist/core/scheduler/types.d.ts.map +1 -0
  119. package/dist/core/scheduler/types.js +1 -0
  120. package/dist/core/server/request-log-meta.d.ts +5 -0
  121. package/dist/core/server/request-log-meta.d.ts.map +1 -0
  122. package/dist/core/server/request-log-meta.js +1 -0
  123. package/dist/mcp/write/apply-guard.d.ts +7 -0
  124. package/dist/mcp/write/apply-guard.d.ts.map +1 -0
  125. package/dist/mcp/write/apply-guard.js +22 -0
  126. package/dist/mcp/write/openapi-jsdoc.d.ts +2 -0
  127. package/dist/mcp/write/openapi-jsdoc.d.ts.map +1 -0
  128. package/dist/mcp/write/openapi-jsdoc.js +15 -0
  129. package/dist/mcp/write/project-write-handlers.d.ts +46 -0
  130. package/dist/mcp/write/project-write-handlers.d.ts.map +1 -0
  131. package/dist/mcp/write/project-write-handlers.js +304 -0
  132. package/dist/mcp/write/risks.d.ts +3 -0
  133. package/dist/mcp/write/risks.d.ts.map +1 -0
  134. package/dist/mcp/write/risks.js +20 -0
  135. package/dist/mcp/write/route-snippet.d.ts +5 -0
  136. package/dist/mcp/write/route-snippet.d.ts.map +1 -0
  137. package/dist/mcp/write/route-snippet.js +46 -0
  138. package/dist/mcp/write/safe-path.d.ts +3 -0
  139. package/dist/mcp/write/safe-path.d.ts.map +1 -0
  140. package/dist/mcp/write/safe-path.js +16 -0
  141. package/dist/mcp/write/test-file-content.d.ts +8 -0
  142. package/dist/mcp/write/test-file-content.d.ts.map +1 -0
  143. package/dist/mcp/write/test-file-content.js +31 -0
  144. package/dist/mcp/write/unified-diff.d.ts +2 -0
  145. package/dist/mcp/write/unified-diff.d.ts.map +1 -0
  146. package/dist/mcp/write/unified-diff.js +19 -0
  147. package/dist/mcp/write/validation-scaffold.d.ts +2 -0
  148. package/dist/mcp/write/validation-scaffold.d.ts.map +1 -0
  149. package/dist/mcp/write/validation-scaffold.js +31 -0
  150. package/dist/mcp-docs-server/resources/configuration.d.ts +3 -0
  151. package/dist/mcp-docs-server/resources/configuration.d.ts.map +1 -0
  152. package/dist/mcp-docs-server/resources/configuration.js +25 -0
  153. package/dist/mcp-docs-server/resources/context.d.ts +3 -0
  154. package/dist/mcp-docs-server/resources/context.d.ts.map +1 -0
  155. package/dist/mcp-docs-server/resources/context.js +34 -0
  156. package/dist/mcp-docs-server/resources/errors.d.ts +3 -0
  157. package/dist/mcp-docs-server/resources/errors.d.ts.map +1 -0
  158. package/dist/mcp-docs-server/resources/errors.js +27 -0
  159. package/dist/mcp-docs-server/resources/introspection.d.ts +3 -0
  160. package/dist/mcp-docs-server/resources/introspection.d.ts.map +1 -0
  161. package/dist/mcp-docs-server/resources/introspection.js +24 -0
  162. package/dist/mcp-docs-server/resources/middlewares.d.ts +3 -0
  163. package/dist/mcp-docs-server/resources/middlewares.d.ts.map +1 -0
  164. package/dist/mcp-docs-server/resources/middlewares.js +36 -0
  165. package/dist/mcp-docs-server/resources/plugin-api.d.ts +3 -0
  166. package/dist/mcp-docs-server/resources/plugin-api.d.ts.map +1 -0
  167. package/dist/mcp-docs-server/resources/plugin-api.js +32 -0
  168. package/dist/mcp-docs-server/resources/response.d.ts +3 -0
  169. package/dist/mcp-docs-server/resources/response.d.ts.map +1 -0
  170. package/dist/mcp-docs-server/resources/response.js +39 -0
  171. package/dist/mcp-docs-server/resources/routing.d.ts +3 -0
  172. package/dist/mcp-docs-server/resources/routing.d.ts.map +1 -0
  173. package/dist/mcp-docs-server/resources/routing.js +47 -0
  174. package/dist/mcp-docs-server/resources/validation.d.ts +3 -0
  175. package/dist/mcp-docs-server/resources/validation.d.ts.map +1 -0
  176. package/dist/mcp-docs-server/resources/validation.js +37 -0
  177. package/dist/mcp-docs-server/resources/websockets.d.ts +3 -0
  178. package/dist/mcp-docs-server/resources/websockets.d.ts.map +1 -0
  179. package/dist/mcp-docs-server/resources/websockets.js +42 -0
  180. package/dist/mcp-docs-server/start-mcp-docs-server.d.ts +2 -0
  181. package/dist/mcp-docs-server/start-mcp-docs-server.d.ts.map +1 -0
  182. package/dist/mcp-docs-server/start-mcp-docs-server.js +171 -0
  183. package/dist/mcp-docs-server/tools/create-middleware.d.ts +5 -0
  184. package/dist/mcp-docs-server/tools/create-middleware.d.ts.map +1 -0
  185. package/dist/mcp-docs-server/tools/create-middleware.js +29 -0
  186. package/dist/mcp-docs-server/tools/create-route.d.ts +5 -0
  187. package/dist/mcp-docs-server/tools/create-route.d.ts.map +1 -0
  188. package/dist/mcp-docs-server/tools/create-route.js +44 -0
  189. package/dist/mcp-docs-server/tools/create-socket.d.ts +5 -0
  190. package/dist/mcp-docs-server/tools/create-socket.d.ts.map +1 -0
  191. package/dist/mcp-docs-server/tools/create-socket.js +39 -0
  192. package/dist/mcp-docs-server/tools/suggest-vite-config.d.ts +11 -0
  193. package/dist/mcp-docs-server/tools/suggest-vite-config.d.ts.map +1 -0
  194. package/dist/mcp-docs-server/tools/suggest-vite-config.js +30 -0
  195. package/dist/mcp-docs-server/tools/validate-convention.d.ts +21 -0
  196. package/dist/mcp-docs-server/tools/validate-convention.d.ts.map +1 -0
  197. package/dist/mcp-docs-server/tools/validate-convention.js +48 -0
  198. package/dist/platform/config.d.ts +30 -0
  199. package/dist/platform/config.d.ts.map +1 -0
  200. package/dist/platform/config.js +85 -0
  201. package/dist/platform/correlation.d.ts +5 -0
  202. package/dist/platform/correlation.d.ts.map +1 -0
  203. package/dist/platform/correlation.js +19 -0
  204. package/dist/platform/index.d.ts +5 -0
  205. package/dist/platform/index.d.ts.map +1 -0
  206. package/dist/platform/index.js +3 -0
  207. package/dist/platform/redaction.d.ts +6 -0
  208. package/dist/platform/redaction.d.ts.map +1 -0
  209. package/dist/platform/redaction.js +40 -0
  210. package/dist/plugin/mode.d.ts +5 -0
  211. package/dist/plugin/mode.d.ts.map +1 -0
  212. package/dist/plugin/mode.js +7 -0
  213. package/dist/public/dispatch.d.ts +3 -0
  214. package/dist/public/dispatch.d.ts.map +1 -0
  215. package/dist/public/dispatch.js +1 -0
  216. package/dist/public/doctor.d.ts +3 -0
  217. package/dist/public/doctor.d.ts.map +1 -0
  218. package/dist/public/doctor.js +1 -0
  219. package/dist/public/errors.d.ts +2 -0
  220. package/dist/public/errors.d.ts.map +1 -0
  221. package/dist/public/errors.js +1 -0
  222. package/dist/public/events.d.ts +3 -0
  223. package/dist/public/events.d.ts.map +1 -0
  224. package/dist/public/events.js +1 -0
  225. package/dist/public/generators.d.ts +3 -0
  226. package/dist/public/generators.d.ts.map +1 -0
  227. package/dist/public/generators.js +1 -0
  228. package/dist/public/introspection.d.ts +3 -0
  229. package/dist/public/introspection.d.ts.map +1 -0
  230. package/dist/public/introspection.js +1 -0
  231. package/dist/public/observability.d.ts +3 -0
  232. package/dist/public/observability.d.ts.map +1 -0
  233. package/dist/public/observability.js +1 -0
  234. package/dist/public/platform.d.ts +3 -0
  235. package/dist/public/platform.d.ts.map +1 -0
  236. package/dist/public/platform.js +1 -0
  237. package/dist/public/plugin.d.ts +3 -0
  238. package/dist/public/plugin.d.ts.map +1 -0
  239. package/dist/public/plugin.js +1 -0
  240. package/dist/public/response.d.ts +2 -0
  241. package/dist/public/response.d.ts.map +1 -0
  242. package/dist/public/response.js +1 -0
  243. package/dist/public/scheduler.d.ts +3 -0
  244. package/dist/public/scheduler.d.ts.map +1 -0
  245. package/dist/public/scheduler.js +1 -0
  246. package/dist/public/testing.d.ts +3 -0
  247. package/dist/public/testing.d.ts.map +1 -0
  248. package/dist/public/testing.js +1 -0
  249. package/dist/public/validation.d.ts +3 -0
  250. package/dist/public/validation.d.ts.map +1 -0
  251. package/dist/public/validation.js +1 -0
  252. package/dist/shared/mode.d.ts +5 -0
  253. package/dist/shared/mode.d.ts.map +1 -0
  254. package/dist/shared/mode.js +7 -0
  255. package/dist/testing/testing.d.ts +15 -0
  256. package/dist/testing/testing.d.ts.map +1 -0
  257. package/dist/testing/testing.js +51 -0
  258. package/package.json +1 -1
@@ -0,0 +1,39 @@
1
+ function pathToFileSegment(segment) {
2
+ if (/^\[\.\.\.[^\]]+\]$/.test(segment))
3
+ return segment;
4
+ if (/^\[[^\]]+\]$/.test(segment))
5
+ return segment;
6
+ if (segment.startsWith('*'))
7
+ return `[...${segment.slice(1)}]`;
8
+ if (segment.startsWith(':'))
9
+ return `[${segment.slice(1)}]`;
10
+ return segment;
11
+ }
12
+ export function pathToSocketFilePath(pattern, apiDir = 'src/api') {
13
+ const normalized = pattern.replace(/\\/g, '/').replace(/^\/+|\/+$/g, '');
14
+ const segments = normalized ? normalized.split('/').filter(Boolean) : [];
15
+ const fileSegments = segments.map((s) => pathToFileSegment(s));
16
+ const pathPart = fileSegments.length ? fileSegments.join('/') : 'index';
17
+ const filePath = `${apiDir}/${pathPart}.socket.ts`.replace(/\/+/g, '/');
18
+ const paramNames = segments
19
+ .filter((s) => s.startsWith(':') || s.startsWith('*') || /^\[\.\.\.[^\]]+\]$/.test(s) || /^\[[^\]]+\]$/.test(s))
20
+ .map((s) => {
21
+ if (s.startsWith('*'))
22
+ return s.slice(1);
23
+ if (s.startsWith(':'))
24
+ return s.slice(1);
25
+ const m = s.match(/^\[\.\.\.?([^\]]+)\]$/);
26
+ return m ? m[1] : s;
27
+ });
28
+ const paramsSnippet = paramNames.length > 0
29
+ ? ` const { params } = ctx;\n ctx.socket.on('message', (data) => ctx.socket.send(JSON.stringify({ params, echo: data })));`
30
+ : ` ctx.socket.on('message', (data) => ctx.socket.send(\`Echo: \${data}\`));`;
31
+ const snippet = `import type { VitekSocketContext } from "vitek-plugin";
32
+
33
+ export default function handler(ctx: VitekSocketContext) {
34
+ ${paramsSnippet}
35
+ return () => {};
36
+ }
37
+ `;
38
+ return { filePath, snippet };
39
+ }
@@ -0,0 +1,11 @@
1
+ export interface ViteConfigOptions {
2
+ openApi?: boolean;
3
+ cors?: boolean;
4
+ apiDir?: string;
5
+ apiBasePath?: string;
6
+ sockets?: boolean | {
7
+ path?: string;
8
+ };
9
+ }
10
+ export declare function suggestViteConfig(options?: ViteConfigOptions): string;
11
+ //# sourceMappingURL=suggest-vite-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"suggest-vite-config.d.ts","sourceRoot":"","sources":["../../../src/mcp-docs-server/tools/suggest-vite-config.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,iBAAiB;IAChC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,GAAG;QAAE,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACvC;AAED,wBAAgB,iBAAiB,CAAC,OAAO,GAAE,iBAAsB,GAAG,MAAM,CAwBzE"}
@@ -0,0 +1,30 @@
1
+ export function suggestViteConfig(options = {}) {
2
+ const opts = [];
3
+ if (options.apiDir != null)
4
+ opts.push(`apiDir: "${options.apiDir}"`);
5
+ if (options.apiBasePath != null)
6
+ opts.push(`apiBasePath: "${options.apiBasePath}"`);
7
+ if (options.openApi === true)
8
+ opts.push('openApi: true');
9
+ else if (typeof options.openApi === 'object')
10
+ opts.push('openApi: {}');
11
+ if (options.cors === true)
12
+ opts.push('cors: true');
13
+ else if (typeof options.cors === 'object')
14
+ opts.push('cors: { origin: "https://your-frontend.com" }');
15
+ if (options.sockets === false)
16
+ opts.push('sockets: false');
17
+ else if (typeof options.sockets === 'object' && options.sockets?.path)
18
+ opts.push(`sockets: { path: "${options.sockets.path}" }`);
19
+ const optionsStr = opts.length ? `,\n ${opts.join(',\n ')}` : '';
20
+ return `import { defineConfig } from "vite";
21
+ import { vitek } from "vitek-plugin";
22
+
23
+ export default defineConfig({
24
+ plugins: [
25
+ vitek({${optionsStr}
26
+ }),
27
+ ],
28
+ });
29
+ `;
30
+ }
@@ -0,0 +1,21 @@
1
+ export type ConventionResult = {
2
+ valid: true;
3
+ type: 'route';
4
+ method: string;
5
+ pattern: string;
6
+ params: string[];
7
+ } | {
8
+ valid: true;
9
+ type: 'middleware';
10
+ basePattern: string;
11
+ } | {
12
+ valid: true;
13
+ type: 'socket';
14
+ pattern: string;
15
+ params: string[];
16
+ } | {
17
+ valid: false;
18
+ message: string;
19
+ };
20
+ export declare function validateConvention(filePath: string, apiDir?: string): ConventionResult;
21
+ //# sourceMappingURL=validate-convention.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-convention.d.ts","sourceRoot":"","sources":["../../../src/mcp-docs-server/tools/validate-convention.ts"],"names":[],"mappings":"AAUA,MAAM,MAAM,gBAAgB,GACxB;IAAE,KAAK,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,EAAE,CAAA;CAAE,GACjF;IAAE,KAAK,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,YAAY,CAAC;IAAC,WAAW,EAAE,MAAM,CAAA;CAAE,GACxD;IAAE,KAAK,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE,QAAQ,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,EAAE,CAAA;CAAE,GAClE;IAAE,KAAK,EAAE,KAAK,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC;AAEtC,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,GAAE,MAAkB,GAAG,gBAAgB,CAwCjG"}
@@ -0,0 +1,48 @@
1
+ const ROUTE_FILE_PATTERN = /^(.+)\.(get|post|put|patch|delete|head|options)\.(ts|js)$/;
2
+ const MIDDLEWARE_FILE_PATTERN = /^middleware\.(ts|js)$/;
3
+ const SOCKET_FILE_PATTERN = /^(.+)\.socket\.(ts|js)$/;
4
+ function normalizePathPart(pathPart) {
5
+ return pathPart
6
+ .replace(/\[\.\.\.([^\]]+)\]/g, '*$1')
7
+ .replace(/\[([^\]]+)\]/g, ':$1');
8
+ }
9
+ export function validateConvention(filePath, apiDir = 'src/api') {
10
+ const normalized = filePath.replace(/\\/g, '/');
11
+ const apiDirNorm = apiDir.replace(/\\/g, '/').replace(/\/+$/, '');
12
+ let relative = normalized;
13
+ if (normalized.includes(apiDirNorm + '/')) {
14
+ relative = normalized.slice(normalized.indexOf(apiDirNorm) + apiDirNorm.length).replace(/^\//, '');
15
+ }
16
+ else if (normalized.startsWith(apiDirNorm)) {
17
+ relative = normalized.slice(apiDirNorm.length).replace(/^\//, '');
18
+ }
19
+ const routeMatch = relative.match(ROUTE_FILE_PATTERN);
20
+ if (routeMatch) {
21
+ const [, pathPart, method] = routeMatch;
22
+ const pattern = normalizePathPart(pathPart.replace(/\/index$/, '').replace(/^\/+/, ''));
23
+ const params = [];
24
+ const paramRegex = /[:*]([^/]+)/g;
25
+ let m;
26
+ while ((m = paramRegex.exec(pattern)) !== null)
27
+ params.push(m[1]);
28
+ return { valid: true, type: 'route', method: method.toLowerCase(), pattern, params };
29
+ }
30
+ if (MIDDLEWARE_FILE_PATTERN.test(relative) || relative.endsWith('/middleware.ts') || relative.endsWith('/middleware.js')) {
31
+ const basePattern = relative.includes('/')
32
+ ? normalizePathPart(relative.replace(/\/middleware\.(ts|js)$/, '').replace(/^\//, ''))
33
+ : '';
34
+ return { valid: true, type: 'middleware', basePattern };
35
+ }
36
+ const socketMatch = relative.match(SOCKET_FILE_PATTERN);
37
+ if (socketMatch) {
38
+ const [, pathPart] = socketMatch;
39
+ const pattern = normalizePathPart(pathPart.replace(/\/index$/, '').replace(/^\/+/, ''));
40
+ const params = [];
41
+ const paramRegex = /[:*]([^/]+)/g;
42
+ let m;
43
+ while ((m = paramRegex.exec(pattern)) !== null)
44
+ params.push(m[1]);
45
+ return { valid: true, type: 'socket', pattern, params };
46
+ }
47
+ return { valid: false, message: 'Not a Vitek route, middleware, or socket file. Expected [name].[method].ts, middleware.ts, or [name].socket.ts' };
48
+ }
@@ -0,0 +1,30 @@
1
+ export interface FeatureFlags {
2
+ observability: boolean;
3
+ contracts: boolean;
4
+ mcpWriteTools: boolean;
5
+ issueDispatch: boolean;
6
+ dataGenerators: boolean;
7
+ doctor: boolean;
8
+ }
9
+ export interface RedactionPolicy {
10
+ stripHeaders: string[];
11
+ stripFields: string[];
12
+ }
13
+ export type AiProvider = 'openai' | 'anthropic' | 'local';
14
+ export type AiMode = 'off' | 'local-only' | 'remote-redacted';
15
+ export interface AiAnalyzerConfig {
16
+ enabled: boolean;
17
+ provider: AiProvider;
18
+ model: string;
19
+ mode: AiMode;
20
+ redaction: RedactionPolicy;
21
+ }
22
+ export interface PlatformConfig {
23
+ features: FeatureFlags;
24
+ ai: AiAnalyzerConfig;
25
+ }
26
+ export declare const DEFAULT_PLATFORM_CONFIG: PlatformConfig;
27
+ export declare function mergePlatformConfig(raw: unknown): PlatformConfig;
28
+ export declare function loadPlatformConfig(root: string): PlatformConfig;
29
+ export declare function isFeatureEnabled(config: PlatformConfig, feature: keyof FeatureFlags): boolean;
30
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/platform/config.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAC3B,aAAa,EAAE,OAAO,CAAC;IACvB,SAAS,EAAE,OAAO,CAAC;IACnB,aAAa,EAAE,OAAO,CAAC;IACvB,aAAa,EAAE,OAAO,CAAC;IACvB,cAAc,EAAE,OAAO,CAAC;IACxB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,MAAM,MAAM,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,OAAO,CAAC;AAC1D,MAAM,MAAM,MAAM,GAAG,KAAK,GAAG,YAAY,GAAG,iBAAiB,CAAC;AAE9D,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,UAAU,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,eAAe,CAAC;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,YAAY,CAAC;IACvB,EAAE,EAAE,gBAAgB,CAAC;CACtB;AA6BD,eAAO,MAAM,uBAAuB,EAAE,cAmBrC,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,OAAO,GAAG,cAAc,CAsBhE;AAED,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,CAY/D;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,YAAY,GAAG,OAAO,CAE7F"}
@@ -0,0 +1,85 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import { z } from 'zod';
4
+ const featureFlagsSchema = z.object({
5
+ observability: z.boolean().optional(),
6
+ contracts: z.boolean().optional(),
7
+ mcpWriteTools: z.boolean().optional(),
8
+ issueDispatch: z.boolean().optional(),
9
+ dataGenerators: z.boolean().optional(),
10
+ doctor: z.boolean().optional(),
11
+ });
12
+ const redactionPolicySchema = z.object({
13
+ stripHeaders: z.array(z.string()).optional(),
14
+ stripFields: z.array(z.string()).optional(),
15
+ });
16
+ const aiAnalyzerSchema = z.object({
17
+ enabled: z.boolean().optional(),
18
+ provider: z.enum(['openai', 'anthropic', 'local']).optional(),
19
+ model: z.string().min(1).optional(),
20
+ mode: z.enum(['off', 'local-only', 'remote-redacted']).optional(),
21
+ redaction: redactionPolicySchema.optional(),
22
+ });
23
+ const platformConfigSchema = z.object({
24
+ features: featureFlagsSchema.optional(),
25
+ ai: aiAnalyzerSchema.optional(),
26
+ });
27
+ export const DEFAULT_PLATFORM_CONFIG = {
28
+ features: {
29
+ observability: false,
30
+ contracts: false,
31
+ mcpWriteTools: false,
32
+ issueDispatch: false,
33
+ dataGenerators: false,
34
+ doctor: false,
35
+ },
36
+ ai: {
37
+ enabled: false,
38
+ provider: 'openai',
39
+ model: 'gpt-4.1-mini',
40
+ mode: 'off',
41
+ redaction: {
42
+ stripHeaders: ['authorization', 'cookie'],
43
+ stripFields: ['password', 'token', 'secret'],
44
+ },
45
+ },
46
+ };
47
+ export function mergePlatformConfig(raw) {
48
+ const parsed = platformConfigSchema.parse(raw);
49
+ return {
50
+ features: {
51
+ observability: parsed.features?.observability ?? DEFAULT_PLATFORM_CONFIG.features.observability,
52
+ contracts: parsed.features?.contracts ?? DEFAULT_PLATFORM_CONFIG.features.contracts,
53
+ mcpWriteTools: parsed.features?.mcpWriteTools ?? DEFAULT_PLATFORM_CONFIG.features.mcpWriteTools,
54
+ issueDispatch: parsed.features?.issueDispatch ?? DEFAULT_PLATFORM_CONFIG.features.issueDispatch,
55
+ dataGenerators: parsed.features?.dataGenerators ?? DEFAULT_PLATFORM_CONFIG.features.dataGenerators,
56
+ doctor: parsed.features?.doctor ?? DEFAULT_PLATFORM_CONFIG.features.doctor,
57
+ },
58
+ ai: {
59
+ enabled: parsed.ai?.enabled ?? DEFAULT_PLATFORM_CONFIG.ai.enabled,
60
+ provider: parsed.ai?.provider ?? DEFAULT_PLATFORM_CONFIG.ai.provider,
61
+ model: parsed.ai?.model ?? DEFAULT_PLATFORM_CONFIG.ai.model,
62
+ mode: parsed.ai?.mode ?? DEFAULT_PLATFORM_CONFIG.ai.mode,
63
+ redaction: {
64
+ stripHeaders: parsed.ai?.redaction?.stripHeaders ?? DEFAULT_PLATFORM_CONFIG.ai.redaction.stripHeaders,
65
+ stripFields: parsed.ai?.redaction?.stripFields ?? DEFAULT_PLATFORM_CONFIG.ai.redaction.stripFields,
66
+ },
67
+ },
68
+ };
69
+ }
70
+ export function loadPlatformConfig(root) {
71
+ const configPath = path.join(root, 'vitek.platform.json');
72
+ if (!fs.existsSync(configPath)) {
73
+ return { ...DEFAULT_PLATFORM_CONFIG, features: { ...DEFAULT_PLATFORM_CONFIG.features }, ai: { ...DEFAULT_PLATFORM_CONFIG.ai, redaction: { ...DEFAULT_PLATFORM_CONFIG.ai.redaction } } };
74
+ }
75
+ try {
76
+ const raw = JSON.parse(fs.readFileSync(configPath, 'utf-8'));
77
+ return mergePlatformConfig(raw);
78
+ }
79
+ catch {
80
+ return { ...DEFAULT_PLATFORM_CONFIG, features: { ...DEFAULT_PLATFORM_CONFIG.features }, ai: { ...DEFAULT_PLATFORM_CONFIG.ai, redaction: { ...DEFAULT_PLATFORM_CONFIG.ai.redaction } } };
81
+ }
82
+ }
83
+ export function isFeatureEnabled(config, feature) {
84
+ return config.features[feature] === true;
85
+ }
@@ -0,0 +1,5 @@
1
+ import type { IncomingMessage } from 'node:http';
2
+ export declare function sanitizeIncomingRequestId(raw: string | undefined): string | null;
3
+ export declare function readRequestIdFromHeaders(headers: IncomingMessage['headers']): string | null;
4
+ export declare function getOrCreateRequestId(headers: IncomingMessage['headers']): string;
5
+ //# sourceMappingURL=correlation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"correlation.d.ts","sourceRoot":"","sources":["../../src/platform/correlation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAKjD,wBAAgB,yBAAyB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,MAAM,GAAG,IAAI,CAKhF;AAED,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,eAAe,CAAC,SAAS,CAAC,GAAG,MAAM,GAAG,IAAI,CAI3F;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,eAAe,CAAC,SAAS,CAAC,GAAG,MAAM,CAEhF"}
@@ -0,0 +1,19 @@
1
+ import { randomUUID } from 'node:crypto';
2
+ const MAX_REQUEST_ID_LENGTH = 128;
3
+ const REQUEST_ID_PATTERN = /^[a-zA-Z0-9-]+$/;
4
+ export function sanitizeIncomingRequestId(raw) {
5
+ if (raw == null || typeof raw !== 'string')
6
+ return null;
7
+ const trimmed = raw.trim().slice(0, MAX_REQUEST_ID_LENGTH);
8
+ if (trimmed.length === 0 || !REQUEST_ID_PATTERN.test(trimmed))
9
+ return null;
10
+ return trimmed;
11
+ }
12
+ export function readRequestIdFromHeaders(headers) {
13
+ const v = headers['x-request-id'];
14
+ const s = Array.isArray(v) ? v[0] : v;
15
+ return sanitizeIncomingRequestId(s);
16
+ }
17
+ export function getOrCreateRequestId(headers) {
18
+ return readRequestIdFromHeaders(headers) ?? randomUUID();
19
+ }
@@ -0,0 +1,5 @@
1
+ export { DEFAULT_PLATFORM_CONFIG, mergePlatformConfig, loadPlatformConfig, isFeatureEnabled, } from './config.js';
2
+ export type { FeatureFlags, RedactionPolicy, AiProvider, AiMode, AiAnalyzerConfig, PlatformConfig, } from './config.js';
3
+ export { REDACTED_VALUE, redactHeaders, redactObject, } from './redaction.js';
4
+ export { sanitizeIncomingRequestId, readRequestIdFromHeaders, getOrCreateRequestId, } from './correlation.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/platform/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,aAAa,CAAC;AACrB,YAAY,EACV,YAAY,EACZ,eAAe,EACf,UAAU,EACV,MAAM,EACN,gBAAgB,EAChB,cAAc,GACf,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,cAAc,EACd,aAAa,EACb,YAAY,GACb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,yBAAyB,EACzB,wBAAwB,EACxB,oBAAoB,GACrB,MAAM,kBAAkB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { DEFAULT_PLATFORM_CONFIG, mergePlatformConfig, loadPlatformConfig, isFeatureEnabled, } from './config.js';
2
+ export { REDACTED_VALUE, redactHeaders, redactObject, } from './redaction.js';
3
+ export { sanitizeIncomingRequestId, readRequestIdFromHeaders, getOrCreateRequestId, } from './correlation.js';
@@ -0,0 +1,6 @@
1
+ import type { RedactionPolicy } from './config.js';
2
+ declare const REDACTED_VALUE = "[REDACTED]";
3
+ export declare function redactHeaders(headers: Record<string, string | string[] | undefined>, policy: RedactionPolicy): Record<string, string | string[] | undefined>;
4
+ export declare function redactObject<T>(input: T, policy: RedactionPolicy): T;
5
+ export { REDACTED_VALUE };
6
+ //# sourceMappingURL=redaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redaction.d.ts","sourceRoot":"","sources":["../../src/platform/redaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnD,QAAA,MAAM,cAAc,eAAe,CAAC;AAMpC,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,EACtD,MAAM,EAAE,eAAe,GACtB,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,CAW/C;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,eAAe,GAAG,CAAC,CAsBpE;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -0,0 +1,40 @@
1
+ const REDACTED_VALUE = '[REDACTED]';
2
+ function normalizeSet(values) {
3
+ return new Set(values.map((v) => v.toLowerCase()));
4
+ }
5
+ export function redactHeaders(headers, policy) {
6
+ const blocked = normalizeSet(policy.stripHeaders);
7
+ const out = {};
8
+ for (const [key, value] of Object.entries(headers)) {
9
+ if (blocked.has(key.toLowerCase())) {
10
+ out[key] = REDACTED_VALUE;
11
+ }
12
+ else {
13
+ out[key] = value;
14
+ }
15
+ }
16
+ return out;
17
+ }
18
+ export function redactObject(input, policy) {
19
+ const blocked = normalizeSet(policy.stripFields);
20
+ function walk(value) {
21
+ if (Array.isArray(value)) {
22
+ return value.map(walk);
23
+ }
24
+ if (value !== null && typeof value === 'object') {
25
+ const out = {};
26
+ for (const [key, child] of Object.entries(value)) {
27
+ if (blocked.has(key.toLowerCase())) {
28
+ out[key] = REDACTED_VALUE;
29
+ }
30
+ else {
31
+ out[key] = walk(child);
32
+ }
33
+ }
34
+ return out;
35
+ }
36
+ return value;
37
+ }
38
+ return walk(input);
39
+ }
40
+ export { REDACTED_VALUE };
@@ -0,0 +1,5 @@
1
+ export declare function isProduction(input: {
2
+ mode?: string;
3
+ nodeEnv?: string;
4
+ }): boolean;
5
+ //# sourceMappingURL=mode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mode.d.ts","sourceRoot":"","sources":["../../src/plugin/mode.ts"],"names":[],"mappings":"AAAA,wBAAgB,YAAY,CAAC,KAAK,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAMhF"}
@@ -0,0 +1,7 @@
1
+ export function isProduction(input) {
2
+ const m = input.mode?.trim().toLowerCase();
3
+ if (m !== undefined && m !== '') {
4
+ return m === 'production';
5
+ }
6
+ return input.nodeEnv === 'production';
7
+ }
@@ -0,0 +1,3 @@
1
+ export type { IssueSeverity, IssueSource, IssueSuggestion, IssueEvent, IssueDispatcher, } from '../core/dispatch/types.js';
2
+ export { createNoopIssueDispatcher, createConsoleIssueDispatcher, emitIssueSafe } from '../core/dispatch/index.js';
3
+ //# sourceMappingURL=dispatch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dispatch.d.ts","sourceRoot":"","sources":["../../src/public/dispatch.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,aAAa,EACb,WAAW,EACX,eAAe,EACf,UAAU,EACV,eAAe,GAChB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,yBAAyB,EAAE,4BAA4B,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC"}
@@ -0,0 +1 @@
1
+ export { createNoopIssueDispatcher, createConsoleIssueDispatcher, emitIssueSafe } from '../core/dispatch/index.js';
@@ -0,0 +1,3 @@
1
+ export { buildDoctorReport } from '../core/doctor/index.js';
2
+ export type { DoctorDimensionResult, DoctorReport } from '../core/doctor/index.js';
3
+ //# sourceMappingURL=doctor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"doctor.d.ts","sourceRoot":"","sources":["../../src/public/doctor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,YAAY,EAAE,qBAAqB,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC"}
@@ -0,0 +1 @@
1
+ export { buildDoctorReport } from '../core/doctor/index.js';
@@ -0,0 +1,2 @@
1
+ export { VitekError, HttpError, BadRequestError, UnauthorizedError, ForbiddenError, NotFoundError, ConflictError, ValidationError, TooManyRequestsError, InternalServerError, } from '../shared/errors.js';
2
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/public/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,SAAS,EACT,eAAe,EACf,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,aAAa,EACb,eAAe,EACf,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1 @@
1
+ export { VitekError, HttpError, BadRequestError, UnauthorizedError, ForbiddenError, NotFoundError, ConflictError, ValidationError, TooManyRequestsError, InternalServerError, } from '../shared/errors.js';
@@ -0,0 +1,3 @@
1
+ export { createEventBus } from '../core/events/index.js';
2
+ export type { EventMap, EventHandler, EventBus } from '../core/events/index.js';
3
+ //# sourceMappingURL=events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/public/events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,YAAY,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC"}
@@ -0,0 +1 @@
1
+ export { createEventBus } from '../core/events/index.js';
@@ -0,0 +1,3 @@
1
+ export { generateCrudFiles } from '../core/generators/index.js';
2
+ export type { DataAdapterName, GeneratedFile, CrudGeneratorInput, DataAdapterGenerator, } from '../core/generators/index.js';
3
+ //# sourceMappingURL=generators.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generators.d.ts","sourceRoot":"","sources":["../../src/public/generators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,YAAY,EACV,eAAe,EACf,aAAa,EACb,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1 @@
1
+ export { generateCrudFiles } from '../core/generators/index.js';
@@ -0,0 +1,3 @@
1
+ export { getManifest, getRoutes, getSockets, writeManifest, } from '../core/introspection/manifest.js';
2
+ export type { VitekManifest } from '../core/introspection/manifest.js';
3
+ //# sourceMappingURL=introspection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"introspection.d.ts","sourceRoot":"","sources":["../../src/public/introspection.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,SAAS,EACT,UAAU,EACV,aAAa,GACd,MAAM,mCAAmC,CAAC;AAC3C,YAAY,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC"}
@@ -0,0 +1 @@
1
+ export { getManifest, getRoutes, getSockets, writeManifest, } from '../core/introspection/manifest.js';
@@ -0,0 +1,3 @@
1
+ export { withSpan } from '../core/observability/with-span.js';
2
+ export type { Span } from '../core/observability/with-span.js';
3
+ //# sourceMappingURL=observability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"observability.d.ts","sourceRoot":"","sources":["../../src/public/observability.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oCAAoC,CAAC;AAC9D,YAAY,EAAE,IAAI,EAAE,MAAM,oCAAoC,CAAC"}
@@ -0,0 +1 @@
1
+ export { withSpan } from '../core/observability/with-span.js';
@@ -0,0 +1,3 @@
1
+ export { loadPlatformConfig, mergePlatformConfig, DEFAULT_PLATFORM_CONFIG, isFeatureEnabled, } from '../platform/config.js';
2
+ export type { FeatureFlags, RedactionPolicy, AiProvider, AiMode, AiAnalyzerConfig, PlatformConfig, } from '../platform/config.js';
3
+ //# sourceMappingURL=platform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"platform.d.ts","sourceRoot":"","sources":["../../src/public/platform.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,uBAAuB,EACvB,gBAAgB,GACjB,MAAM,uBAAuB,CAAC;AAC/B,YAAY,EACV,YAAY,EACZ,eAAe,EACf,UAAU,EACV,MAAM,EACN,gBAAgB,EAChB,cAAc,GACf,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1 @@
1
+ export { loadPlatformConfig, mergePlatformConfig, DEFAULT_PLATFORM_CONFIG, isFeatureEnabled, } from '../platform/config.js';
@@ -0,0 +1,3 @@
1
+ export { vitek } from '../plugin.js';
2
+ export type { VitekOptions, CorsOptions } from '../plugin.js';
3
+ //# sourceMappingURL=plugin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../../src/public/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AACrC,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1 @@
1
+ export { vitek } from '../plugin.js';
@@ -0,0 +1,2 @@
1
+ export { json, ok, created, noContent, badRequest, unauthorized, forbidden, notFound, conflict, unprocessableEntity, tooManyRequests, internalServerError, redirect, text, html, cacheControl, noStore, } from '../shared/response-helpers.js';
2
+ //# sourceMappingURL=response.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/public/response.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,IAAI,EACJ,EAAE,EACF,OAAO,EACP,SAAS,EACT,UAAU,EACV,YAAY,EACZ,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,mBAAmB,EACnB,eAAe,EACf,mBAAmB,EACnB,QAAQ,EACR,IAAI,EACJ,IAAI,EACJ,YAAY,EACZ,OAAO,GACR,MAAM,+BAA+B,CAAC"}
@@ -0,0 +1 @@
1
+ export { json, ok, created, noContent, badRequest, unauthorized, forbidden, notFound, conflict, unprocessableEntity, tooManyRequests, internalServerError, redirect, text, html, cacheControl, noStore, } from '../shared/response-helpers.js';
@@ -0,0 +1,3 @@
1
+ export { defineSchedule, runScheduleOnce, InMemoryLockProvider } from '../core/scheduler/index.js';
2
+ export type { ScheduleTask, ScheduleDefinition, TaskRunResult, ScheduleRunResult, SchedulerLockProvider, } from '../core/scheduler/index.js';
3
+ //# sourceMappingURL=scheduler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../../src/public/scheduler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AACnG,YAAY,EACV,YAAY,EACZ,kBAAkB,EAClB,aAAa,EACb,iBAAiB,EACjB,qBAAqB,GACtB,MAAM,4BAA4B,CAAC"}
@@ -0,0 +1 @@
1
+ export { defineSchedule, runScheduleOnce, InMemoryLockProvider } from '../core/scheduler/index.js';
@@ -0,0 +1,3 @@
1
+ export { createMockContext, createMockReq, createMockRes, runMiddlewareChain, } from '../testing/testing.js';
2
+ export type { MockServerResponse } from '../testing/testing.js';
3
+ //# sourceMappingURL=testing.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../../src/public/testing.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,aAAa,EACb,aAAa,EACb,kBAAkB,GACnB,MAAM,uBAAuB,CAAC;AAC/B,YAAY,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1 @@
1
+ export { createMockContext, createMockReq, createMockRes, runMiddlewareChain, } from '../testing/testing.js';
@@ -0,0 +1,3 @@
1
+ export { validate, validateOrThrow, validateBody, validateQuery, } from '../core/validation/validator.js';
2
+ export type { ValidationSchema, ValidationRule, ValidationResult, } from '../core/validation/types.js';
3
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/public/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EACR,eAAe,EACf,YAAY,EACZ,aAAa,GACd,MAAM,iCAAiC,CAAC;AACzC,YAAY,EACV,gBAAgB,EAChB,cAAc,EACd,gBAAgB,GACjB,MAAM,6BAA6B,CAAC"}
@@ -0,0 +1 @@
1
+ export { validate, validateOrThrow, validateBody, validateQuery, } from '../core/validation/validator.js';
@@ -0,0 +1,5 @@
1
+ export declare function isProduction(input: {
2
+ mode?: string;
3
+ nodeEnv?: string;
4
+ }): boolean;
5
+ //# sourceMappingURL=mode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mode.d.ts","sourceRoot":"","sources":["../../src/shared/mode.ts"],"names":[],"mappings":"AAAA,wBAAgB,YAAY,CAAC,KAAK,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAMhF"}
@@ -0,0 +1,7 @@
1
+ export function isProduction(input) {
2
+ const m = input.mode?.trim().toLowerCase();
3
+ if (m !== undefined && m !== '') {
4
+ return m === 'production';
5
+ }
6
+ return input.nodeEnv === 'production';
7
+ }
@@ -0,0 +1,15 @@
1
+ import type { VitekContext, VitekRequest } from '../core/context/create-context.js';
2
+ import type { Middleware } from '../core/routing/route-types.js';
3
+ export interface MockServerResponse {
4
+ statusCode: number;
5
+ headers: Record<string, string | number | string[]>;
6
+ bodyChunks: Buffer[];
7
+ setHeader(name: string, value: string | number | string[]): void;
8
+ getHeader(name: string): string | number | string[] | undefined;
9
+ end(chunk?: string | Buffer): void;
10
+ }
11
+ export declare function createMockContext(overrides?: Partial<VitekContext>): VitekContext;
12
+ export declare function createMockReq(overrides?: Partial<VitekRequest>): VitekRequest;
13
+ export declare function createMockRes(): MockServerResponse;
14
+ export declare function runMiddlewareChain(context: VitekContext, middlewares: Middleware[]): Promise<void>;
15
+ //# sourceMappingURL=testing.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../../src/testing/testing.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAEpF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAEjE,MAAM,WAAW,kBAAkB;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,CAAC,CAAC;IACpD,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,IAAI,CAAC;IACjE,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC;IAChE,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAC;CACpC;AAED,wBAAgB,iBAAiB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,YAAY,CAejF;AAED,wBAAgB,aAAa,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,YAAY,CAQ7E;AAED,wBAAgB,aAAa,IAAI,kBAAkB,CAoBlD;AAED,wBAAsB,kBAAkB,CACtC,OAAO,EAAE,YAAY,EACrB,WAAW,EAAE,UAAU,EAAE,GACxB,OAAO,CAAC,IAAI,CAAC,CAGf"}