@kosmojs/dev 0.0.7 → 0.0.9

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 (156) hide show
  1. package/package.json +7 -6
  2. package/pkg/base-plugin/routes.js +384 -216
  3. package/pkg/base-plugin/routes.js.map +4 -4
  4. package/pkg/base-plugin/worker.js +297 -235
  5. package/pkg/base-plugin/worker.js.map +4 -4
  6. package/pkg/cli/cli.js +4 -8
  7. package/pkg/cli/cli.js.map +2 -2
  8. package/pkg/cli/index.js +4 -8
  9. package/pkg/cli/index.js.map +2 -2
  10. package/pkg/index.js +286 -219
  11. package/pkg/index.js.map +4 -4
  12. package/pkg/src/base-plugin/cache.d.ts +1 -1
  13. package/pkg/src/base-plugin/routes/nesting.d.ts +5 -0
  14. package/pkg/src/base-plugin/routes/resolve.d.ts +23 -0
  15. package/pkg/src/base-plugin/routes.d.ts +6 -10
  16. package/pkg/src/index.d.ts +1 -1
  17. package/pkg/stub-generator/index.js +5 -4
  18. package/pkg/stub-generator/index.js.map +2 -2
  19. package/pkg/test/@fixtures/app/@src/pages/about/careers/[jobId]/index.d.ts +0 -0
  20. package/pkg/test/@fixtures/app/@src/pages/about/careers/layout.d.ts +0 -0
  21. package/pkg/test/@fixtures/app/@src/pages/about/index.d.ts +0 -0
  22. package/pkg/test/@fixtures/app/@src/pages/about/layout.d.ts +0 -0
  23. package/pkg/test/@fixtures/app/@src/pages/about/team/index.d.ts +0 -0
  24. package/pkg/test/@fixtures/app/@src/pages/account/layout.d.ts +0 -0
  25. package/pkg/test/@fixtures/app/@src/pages/account/profile/index.d.ts +0 -0
  26. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/index.d.ts +0 -0
  27. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/resources/[[type]]/[...path]/index.d.ts +0 -0
  28. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/resources/[[type]]/index.d.ts +0 -0
  29. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/resources/[[type]]/layout.d.ts +0 -0
  30. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/resources/index.d.ts +0 -0
  31. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/resources/layout.d.ts +0 -0
  32. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/settings/general/index.d.ts +0 -0
  33. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/settings/index.d.ts +0 -0
  34. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/settings/layout.d.ts +0 -0
  35. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/settings/permissions/index.d.ts +0 -0
  36. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/users/[userId]/index.d.ts +0 -0
  37. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/users/index.d.ts +0 -0
  38. package/pkg/test/@fixtures/app/@src/pages/admin/[tenant]/users/layout.d.ts +0 -0
  39. package/pkg/test/@fixtures/app/@src/pages/admin/index.d.ts +0 -0
  40. package/pkg/test/@fixtures/app/@src/pages/admin/layout.d.ts +0 -0
  41. package/pkg/test/@fixtures/app/@src/pages/blog/[[category]]/[[tag]]/index.d.ts +0 -0
  42. package/pkg/test/@fixtures/app/@src/pages/blog/[[category]]/index.d.ts +0 -0
  43. package/pkg/test/@fixtures/app/@src/pages/blog/index.d.ts +0 -0
  44. package/pkg/test/@fixtures/app/@src/pages/blog/layout.d.ts +0 -0
  45. package/pkg/test/@fixtures/app/@src/pages/blog/post/[slug]/index.d.ts +0 -0
  46. package/pkg/test/@fixtures/app/@src/pages/blog/post/[slug]/layout.d.ts +0 -0
  47. package/pkg/test/@fixtures/app/@src/pages/contact/index.d.ts +0 -0
  48. package/pkg/test/@fixtures/app/@src/pages/contact/layout.d.ts +0 -0
  49. package/pkg/test/@fixtures/app/@src/pages/courses/[courseId]/layout.d.ts +0 -0
  50. package/pkg/test/@fixtures/app/@src/pages/courses/[courseId]/lessons/[[lessonId]]/assignments/[...assignmentPath]/index.d.ts +0 -0
  51. package/pkg/test/@fixtures/app/@src/pages/dashboard/[view]/index.d.ts +0 -0
  52. package/pkg/test/@fixtures/app/@src/pages/dashboard/analytics/index.d.ts +0 -0
  53. package/pkg/test/@fixtures/app/@src/pages/dashboard/index.d.ts +0 -0
  54. package/pkg/test/@fixtures/app/@src/pages/dashboard/layout.d.ts +0 -0
  55. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/billing/index.d.ts +0 -0
  56. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/index.d.ts +0 -0
  57. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/layout.d.ts +0 -0
  58. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/notifications/index.d.ts +0 -0
  59. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/profile/index.d.ts +0 -0
  60. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/security/index.d.ts +0 -0
  61. package/pkg/test/@fixtures/app/@src/pages/dashboard/settings/security/layout.d.ts +0 -0
  62. package/pkg/test/@fixtures/app/@src/pages/docs/[...path]/index.d.ts +0 -0
  63. package/pkg/test/@fixtures/app/@src/pages/docs/index.d.ts +0 -0
  64. package/pkg/test/@fixtures/app/@src/pages/docs/layout.d.ts +0 -0
  65. package/pkg/test/@fixtures/app/@src/pages/files/[...filePath]/index.d.ts +0 -0
  66. package/pkg/test/@fixtures/app/@src/pages/files/[...filePath]/layout.d.ts +0 -0
  67. package/pkg/test/@fixtures/app/@src/pages/legal/layout.d.ts +0 -0
  68. package/pkg/test/@fixtures/app/@src/pages/legal/privacy/index.d.ts +0 -0
  69. package/pkg/test/@fixtures/app/@src/pages/legal/terms/index.d.ts +0 -0
  70. package/pkg/test/@fixtures/app/@src/pages/news/[category]/articles/[...articlePath]/index.d.ts +0 -0
  71. package/pkg/test/@fixtures/app/@src/pages/news/[category]/layout.d.ts +0 -0
  72. package/pkg/test/@fixtures/app/@src/pages/portal/[clientId]/layout.d.ts +0 -0
  73. package/pkg/test/@fixtures/app/@src/pages/portal/[clientId]/reports/[reportType]/data/[dataView]/index.d.ts +0 -0
  74. package/pkg/test/@fixtures/app/@src/pages/portal/[clientId]/reports/[reportType]/data/[dataView]/layout.d.ts +0 -0
  75. package/pkg/test/@fixtures/app/@src/pages/portal/[clientId]/reports/[reportType]/layout.d.ts +0 -0
  76. package/pkg/test/@fixtures/app/@src/pages/portal/[clientId]/reports/layout.d.ts +0 -0
  77. package/pkg/test/@fixtures/app/@src/pages/portal/layout.d.ts +0 -0
  78. package/pkg/test/@fixtures/app/@src/pages/products/[id]/index.d.ts +0 -0
  79. package/pkg/test/@fixtures/app/@src/pages/products/index.d.ts +0 -0
  80. package/pkg/test/@fixtures/app/@src/pages/profile/[username]/layout.d.ts +0 -0
  81. package/pkg/test/@fixtures/app/@src/pages/profile/[username]/posts/[postId]/comments/[...thread]/index.d.ts +0 -0
  82. package/pkg/test/@fixtures/app/@src/pages/profile/[username]/posts/[postId]/layout.d.ts +0 -0
  83. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/files/[...path]/index.d.ts +0 -0
  84. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/files/index.d.ts +0 -0
  85. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/files/layout.d.ts +0 -0
  86. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/index.d.ts +0 -0
  87. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/layout.d.ts +0 -0
  88. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/[taskId]/comments/[commentId]/index.d.ts +0 -0
  89. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/[taskId]/comments/index.d.ts +0 -0
  90. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/[taskId]/comments/layout.d.ts +0 -0
  91. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/[taskId]/index.d.ts +0 -0
  92. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/[taskId]/layout.d.ts +0 -0
  93. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/index.d.ts +0 -0
  94. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/tasks/layout.d.ts +0 -0
  95. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/team/[userId]/index.d.ts +0 -0
  96. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/team/index.d.ts +0 -0
  97. package/pkg/test/@fixtures/app/@src/pages/projects/[projectId]/team/layout.d.ts +0 -0
  98. package/pkg/test/@fixtures/app/@src/pages/projects/index.d.ts +0 -0
  99. package/pkg/test/@fixtures/app/@src/pages/projects/layout.d.ts +0 -0
  100. package/pkg/test/@fixtures/app/@src/pages/properties/[[city]]/filters/[...filters]/index.d.ts +0 -0
  101. package/pkg/test/@fixtures/app/@src/pages/properties/filters/index.d.ts +0 -0
  102. package/pkg/test/@fixtures/app/@src/pages/properties/layout.d.ts +0 -0
  103. package/pkg/test/@fixtures/app/@src/pages/search/[[query]]/[[page]]/index.d.ts +0 -0
  104. package/pkg/test/@fixtures/app/@src/pages/search/[[query]]/layout.d.ts +0 -0
  105. package/pkg/test/@fixtures/app/@src/pages/search/index.d.ts +0 -0
  106. package/pkg/test/@fixtures/app/@src/pages/shop/[category]/[productId]/index.d.ts +0 -0
  107. package/pkg/test/@fixtures/app/@src/pages/shop/[category]/[productId]/layout.d.ts +0 -0
  108. package/pkg/test/@fixtures/app/@src/pages/shop/cart/index.d.ts +0 -0
  109. package/pkg/test/@fixtures/app/@src/pages/shop/checkout/confirm/index.d.ts +0 -0
  110. package/pkg/test/@fixtures/app/@src/pages/shop/checkout/layout.d.ts +0 -0
  111. package/pkg/test/@fixtures/app/@src/pages/shop/checkout/payment/index.d.ts +0 -0
  112. package/pkg/test/@fixtures/app/@src/pages/shop/checkout/shipping/index.d.ts +0 -0
  113. package/pkg/test/@fixtures/app/@src/pages/shop/checkout/shipping/layout.d.ts +0 -0
  114. package/pkg/test/@fixtures/app/@src/pages/shop/index.d.ts +0 -0
  115. package/pkg/test/@fixtures/app/@src/pages/shop/layout.d.ts +0 -0
  116. package/pkg/test/@fixtures/app/@src/pages/shop/orders/[orderId]/index.d.ts +0 -0
  117. package/pkg/test/@fixtures/app/@src/pages/shop/orders/index.d.ts +0 -0
  118. package/pkg/test/@fixtures/app/@src/pages/shop/orders/layout.d.ts +0 -0
  119. package/pkg/test/@fixtures/app/@src/pages/shop/product/[id]/index.d.ts +0 -0
  120. package/pkg/test/@fixtures/app/@src/pages/shop/product/[id]/layout.d.ts +0 -0
  121. package/pkg/test/@fixtures/app/@src/pages/shop/product/[id]/reviews/index.d.ts +0 -0
  122. package/pkg/test/@fixtures/app/@src/pages/shop/products/[[category]]/index.d.ts +0 -0
  123. package/pkg/test/@fixtures/app/@src/pages/shop/products/index.d.ts +0 -0
  124. package/pkg/test/@fixtures/app/@src/pages/shop/products/layout.d.ts +0 -0
  125. package/pkg/test/@fixtures/app/@src/pages/signup/index.d.ts +0 -0
  126. package/pkg/test/@fixtures/app/@src/pages/store/[category]/filters/[...filters]/index.d.ts +0 -0
  127. package/pkg/test/@fixtures/app/@src/pages/store/[category]/sort/[sortBy]/index.d.ts +0 -0
  128. package/pkg/test/@fixtures/app/@src/pages/store/[category]/sort/layout.d.ts +0 -0
  129. package/pkg/test/@fixtures/app/@src/pages/store/layout.d.ts +0 -0
  130. package/pkg/test/@fixtures/app/@src/pages/users/[username]/followers/index.d.ts +0 -0
  131. package/pkg/test/@fixtures/app/@src/pages/users/[username]/following/index.d.ts +0 -0
  132. package/pkg/test/@fixtures/app/@src/pages/users/[username]/index.d.ts +0 -0
  133. package/pkg/test/@fixtures/app/@src/pages/users/[username]/layout.d.ts +0 -0
  134. package/pkg/test/@fixtures/app/@src/pages/users/[username]/posts/[postId]/index.d.ts +0 -0
  135. package/pkg/test/@fixtures/app/@src/pages/users/[username]/posts/[postId]/layout.d.ts +0 -0
  136. package/pkg/test/@fixtures/app/@src/pages/users/[username]/posts/index.d.ts +0 -0
  137. package/pkg/test/@fixtures/app/@src/pages/users/[username]/posts/layout.d.ts +0 -0
  138. package/pkg/test/@fixtures/app/@src/pages/users/index.d.ts +0 -0
  139. package/pkg/test/@fixtures/app/@src/pages/users/layout.d.ts +0 -0
  140. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/analytics/[range]/index.d.ts +0 -0
  141. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/analytics/[range]/layout.d.ts +0 -0
  142. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/analytics/index.d.ts +0 -0
  143. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/analytics/layout.d.ts +0 -0
  144. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/team/[memberId]/permissions/[...permissionPath]/index.d.ts +0 -0
  145. package/pkg/test/@fixtures/app/@src/pages/workspace/[workspaceId]/team/layout.d.ts +0 -0
  146. package/pkg/test/@fixtures/app/lib/@src/{api}/articles/[...path]/index.ts/types.d.ts +3 -0
  147. package/pkg/test/@fixtures/app/lib/@src/{api}/books/[category]/[[author]]/index.ts/types.d.ts +4 -0
  148. package/pkg/test/@fixtures/app/lib/@src/{api}/books/[category]/index.ts/types.d.ts +3 -0
  149. package/pkg/test/@fixtures/app/lib/@src/{api}/books/index.ts/types.d.ts +1 -0
  150. package/pkg/test/@fixtures/app/lib/@src/{api}/files/[[folder]]/[[id]].json/index.ts/types.d.ts +4 -0
  151. package/pkg/test/@fixtures/app/lib/@src/{api}/files/[[folder]]/index.ts/types.d.ts +3 -0
  152. package/pkg/test/@fixtures/app/lib/@src/{api}/index/index.ts/types.d.ts +1 -0
  153. package/pkg/test/@fixtures/app/lib/@src/{api}/pages/[...path].html/index.ts/types.d.ts +3 -0
  154. package/pkg/test/@fixtures/app/lib/@src/{api}/users/[id].json/index.ts/types.d.ts +3 -0
  155. package/pkg/test/routes/base.d.ts +4 -0
  156. package/pkg/test/routes/nesting.test.d.ts +1 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../src/base-plugin/worker.ts", "../../src/base-plugin/routes.ts", "../../src/base-plugin/ast.ts", "../../src/base-plugin/cache.ts", "../../src/base-plugin/templates/resolved-types.hbs", "../../src/base-plugin/templates/types.hbs"],
4
- "sourcesContent": ["import { parentPort, workerData } from \"node:worker_threads\";\n\nimport chokidar from \"chokidar\";\nimport crc from \"crc/crc32\";\n\nimport {\n type Formatter,\n type GeneratorConstructor,\n type PluginOptionsResolved,\n pathResolver,\n type RouteResolver,\n type RouteResolverEntry,\n type WatcherEvent,\n type WatchHandler,\n} from \"@kosmojs/devlib\";\n\nimport routesFactory from \"./routes\";\nimport type { SpinnerFactory } from \"./spinner\";\n\nexport type WorkerData = Omit<\n PluginOptionsResolved,\n \"generators\" | \"formatters\"\n> & {\n generatorModules: Array<[string, unknown]>;\n formatterModules: Array<[string, unknown]>;\n};\n\nexport type WorkerSpinner = {\n id: string;\n startText: string;\n method: keyof SpinnerFactory;\n text?: string | undefined;\n};\n\nexport type WorkerError = {\n name: string;\n message: string;\n stack?: string;\n};\n\nconst {\n //\n generatorModules,\n formatterModules,\n ...restOptions\n} = workerData as WorkerData;\n\nconst generators: Array<GeneratorConstructor> = [];\nconst formatters: Array<Formatter> = [];\n\nfor (const [path, opts] of generatorModules) {\n generators.push(await import(path).then((m) => m.default(opts)));\n}\n\nfor (const [path, opts] of formatterModules) {\n formatters.push(await import(path).then((m) => m.default(opts).formatter));\n}\n\nconst resolvedOptions: PluginOptionsResolved = {\n ...restOptions,\n generators,\n formatters,\n};\n\nconst { appRoot, sourceFolder } = resolvedOptions;\n\nconst watchHandlers: Array<{ name: string; handler: WatchHandler }> = [];\n\nconst resolvedRoutes = new Map<\n string, // fileFullpath\n RouteResolverEntry\n>();\n\nconst {\n //\n resolvers,\n resolversFactory,\n resolveRouteFile,\n} = await routesFactory(resolvedOptions);\n\nconst { resolve } = pathResolver({ appRoot, sourceFolder });\n\nconst spinnerFactory = (startText: string) => {\n const id = [startText, Date.now().toString()].map(crc).join(\":\");\n\n const postMessage = (\n method: keyof SpinnerFactory,\n text?: string | undefined,\n ) => {\n const spinner: WorkerSpinner = { id, startText, method, text };\n parentPort?.postMessage({ spinner });\n };\n\n const postError = (error: Error) => {\n parentPort?.postMessage({ error: structuredClone(error) });\n };\n\n return {\n id,\n startText,\n text(text: string) {\n postMessage(\"text\", text);\n },\n append(text: string) {\n postMessage(\"append\", text);\n },\n succeed(text?: string) {\n postMessage(\"succeed\", text);\n },\n failed(error: Error) {\n postError(error);\n postMessage(\"failed\", error?.stack || error?.message);\n },\n };\n};\n\nconst createEventHandler = async (file: string) => {\n const [resolver] = resolversFactory([file]).values();\n if (resolver) {\n const spinner = spinnerFactory(`Resolving ${resolver.name} Route`);\n try {\n const resolvedRoute = await resolver.handler();\n resolvers.set(file, resolver);\n resolvedRoutes.set(resolvedRoute.route.fileFullpath, resolvedRoute);\n spinner.succeed();\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n }\n }\n};\n\nconst updateEventHandler = async (file: string) => {\n const relatedResolvers = new Map<string, RouteResolver>();\n\n if (resolvedRoutes.has(file)) {\n // some route updated\n const resolver = resolvers.get(file);\n if (resolver) {\n relatedResolvers.set(file, resolver);\n }\n } else {\n // checking if changed file is referenced by any routes\n const referencedRoutes = resolvedRoutes\n .values()\n .filter(({ kind, route }) => {\n return kind === \"api\" ? route.referencedFiles.includes(file) : false;\n });\n for (const { route } of referencedRoutes) {\n const resolver = resolvers.get(route.fileFullpath);\n if (resolver) {\n relatedResolvers.set(route.fileFullpath, resolver);\n }\n }\n }\n\n let spinner = spinnerFactory(`Updating ${relatedResolvers.size} Routes`);\n\n for (const resolver of relatedResolvers.values()) {\n spinner.append(resolver.name);\n try {\n const route = await resolver.handler(file);\n resolvedRoutes.set(route.route.fileFullpath, route);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(`Updating ${relatedResolvers.size} Routes`);\n }\n }\n\n spinner.succeed();\n};\n\nconst deleteEventHandler = async () => {\n // TODO: cleanup related files in libDir\n};\n\nconst runWatchHandlers = async (event?: WatcherEvent) => {\n let spinner = spinnerFactory(\"Running Generators\");\n\n /**\n * Watch handlers receive the full list of routes\n * and should process only those whose source file or dependencies were updated.\n */\n const routes = Array.from(resolvedRoutes.values());\n\n for (const { name, handler } of watchHandlers) {\n spinner.append(name);\n try {\n // using structuredClone to make sure no generator would alter routes\n await handler(structuredClone(routes), event);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Running Generators\");\n }\n }\n\n spinner.succeed();\n};\n\nconst watcher = chokidar.watch(\n [\n // watching for changes in sourceFolder's apiDir and pagesDir\n resolve(\"apiDir\"),\n resolve(\"pagesDir\"),\n ],\n {\n ...resolvedOptions.watcher.options,\n awaitWriteFinish:\n typeof resolvedOptions.watcher.options?.awaitWriteFinish === \"object\"\n ? resolvedOptions.watcher.options.awaitWriteFinish\n : {\n stabilityThreshold: resolvedOptions.watcher.delay,\n pollInterval: Math.floor(resolvedOptions.watcher.delay / 4),\n },\n // Do Not emit \"add\" event for existing files\n ignoreInitial: true,\n // Not using Chokidar's `ignored` option.\n // Instead, allow all events through and filter them manually as needed.\n },\n);\n\nwatcher.on(\"all\", async (event, file) => {\n if (event.endsWith(\"Dir\")) {\n // skipping folder events\n return;\n }\n\n if (!resolveRouteFile(file)) {\n // not a route file\n return;\n }\n\n const match = (\n {\n add: { handler: createEventHandler, kind: \"create\" },\n change: { handler: updateEventHandler, kind: \"update\" },\n unlink: { handler: deleteEventHandler, kind: \"delete\" },\n } as const\n )[event as string];\n\n if (match) {\n const { handler, kind } = match;\n\n /**\n * This handler is responsible for updating `resolvedRoutes`\n * before they are passed to generators.\n * */\n await handler(file);\n\n await runWatchHandlers({ kind, file });\n }\n});\n\n{\n let spinner = spinnerFactory(\"Resolving Routes\");\n\n for (const { name, handler } of resolvers.values()) {\n spinner.append(\n `[ ${resolvedRoutes.size + 1} of ${resolvers.size} ] ${name}`,\n );\n try {\n const resolvedEntry = await handler();\n resolvedRoutes.set(resolvedEntry.route.fileFullpath, resolvedEntry);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Resolving Routes\");\n }\n }\n\n spinner.succeed();\n}\n\n{\n let spinner = spinnerFactory(\"Initializing Generators\");\n\n for (const { name, factory } of generators) {\n spinner.append(name);\n try {\n const { watchHandler } = await factory(resolvedOptions);\n watchHandlers.push({ name, handler: watchHandler });\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Initializing Generators\");\n }\n }\n\n spinner.succeed();\n}\n\nawait runWatchHandlers();\n\nparentPort?.postMessage(\"ready\");\n", "import { dirname, join, resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\nimport picomatch from \"picomatch\";\nimport { glob } from \"tinyglobby\";\n\nimport {\n type ApiRoute,\n defaults,\n type PageRoute,\n type PluginOptionsResolved,\n pathResolver,\n pathTokensFactory,\n type RouteEntry,\n type RouteResolver,\n render,\n renderToFile,\n} from \"@kosmojs/devlib\";\n\nimport { resolveRouteSignature, typeResolverFactory } from \"./ast\";\nimport { cacheFactory } from \"./cache\";\n\nimport resolvedTypesTpl from \"./templates/resolved-types.hbs\";\nimport typesFileTpl from \"./templates/types.hbs\";\n\nexport type Resolvers = Map<string, RouteResolver>;\n\nexport type ResolveRouteFile = (file: string) =>\n | [\n // Either `apiDir` or `pagesDir`\n folder: string,\n // Path to a file within the folder, nested at least one level deep\n file: string,\n ]\n | undefined;\n\nexport type ResolversFactory = (\n routeFiles: Array<string>,\n) => Map<string, RouteResolver>;\n\nexport default async (\n pluginOptions: PluginOptionsResolved,\n): Promise<{\n resolvers: Resolvers;\n resolversFactory: ResolversFactory;\n resolveRouteFile: ResolveRouteFile;\n}> => {\n const {\n appRoot,\n sourceFolder,\n generators = [],\n formatters = [],\n refineTypeName,\n } = pluginOptions;\n\n let resolveTypes = false;\n\n for (const { options } of generators) {\n if (options?.resolveTypes) {\n resolveTypes = true;\n }\n }\n\n const {\n //\n literalTypesResolver,\n getSourceFile,\n refreshSourceFile,\n } = typeResolverFactory(pluginOptions);\n\n const routeFilePatterns = [\n `${defaults.apiDir}/**/index.ts`,\n `${defaults.pagesDir}/**/index.{ts,tsx,vue,svelte}`,\n ];\n\n const resolveRouteFile: ResolveRouteFile = (file) => {\n const [_sourceFolder, folder, ...rest] = resolve(appRoot, file)\n .replace(`${appRoot}/`, \"\")\n .split(\"/\");\n\n /**\n * Ensure the file:\n * - is under the correct source root (`sourceFolder`)\n * - belongs to a known route folder (`apiDir` or `pagesDir`)\n * - is nested at least one level deep (not a direct child of the folder)\n */\n if (!folder || _sourceFolder !== sourceFolder || rest.length < 2) {\n return;\n }\n\n return picomatch.isMatch(join(folder, ...rest), routeFilePatterns)\n ? [folder, rest.join(\"/\")]\n : undefined;\n };\n\n const resolversFactory: ResolversFactory = (routeFiles) => {\n const resolvers = new Map<\n string, // fileFullpath\n RouteResolver\n >();\n\n const entries: Array<RouteEntry> = routeFiles.flatMap((_file) => {\n const resolvedPaths = resolveRouteFile(_file);\n\n if (!resolvedPaths) {\n return [];\n }\n\n const [folder, file] = resolvedPaths;\n\n const fileFullpath = join(appRoot, sourceFolder, folder, file);\n\n const pathTokens = pathTokensFactory(dirname(file));\n\n const name = pathTokens.map((e) => e.orig).join(\"/\");\n\n const importPath = dirname(file);\n\n const importName = [\n importPath\n .split(/\\[/)[0]\n .replace(/^\\W+|\\W+$/g, \"\")\n .replace(/\\W+/g, \"_\"),\n crc(importPath),\n ].join(\"_\");\n\n return [\n {\n name,\n folder,\n file,\n fileFullpath,\n pathTokens,\n importPath,\n importName,\n },\n ];\n });\n\n for (const entry of entries.filter((e) => e.folder === defaults.apiDir)) {\n const {\n name,\n file,\n folder,\n fileFullpath,\n pathTokens,\n importPath,\n importName,\n } = entry;\n\n const handler: RouteResolver[\"handler\"] = async (updatedFile) => {\n const paramsSchema = pathTokens.flatMap((e) => {\n return e.param ? [e.param] : [];\n });\n\n const optionalParams = paramsSchema.length\n ? !paramsSchema.some((e) => e.isRequired)\n : true;\n\n const { getCache, persistCache } = cacheFactory(\n { file, fileFullpath, importName, importPath },\n {\n appRoot,\n sourceFolder,\n extraContext: { resolveTypes },\n },\n );\n\n let cache = await getCache({ validate: true });\n\n if (!cache) {\n if (updatedFile === fileFullpath) {\n await refreshSourceFile(fileFullpath);\n }\n\n const {\n typeDeclarations,\n paramsRefinements,\n methods,\n payloadTypes,\n responseTypes,\n referencedFiles = [],\n } = await resolveRouteSignature(\n { importName, fileFullpath, optionalParams },\n {\n withReferencedFiles: true,\n sourceFile: getSourceFile(fileFullpath),\n relpathResolver(path) {\n return join(sourceFolder, defaults.apiDir, dirname(file), path);\n },\n },\n );\n\n const numericParams = paramsRefinements\n ? paramsRefinements.flatMap(({ text, index }) => {\n if (text === \"number\") {\n const param = paramsSchema.at(index);\n return param ? [param.name] : [];\n }\n return [];\n })\n : [];\n\n const typesFile = pathResolver({ appRoot, sourceFolder }).resolve(\n \"apiLibDir\",\n importPath,\n \"types.ts\",\n );\n\n const params: ApiRoute[\"params\"] = {\n id: [\"ParamsT\", crc(name)].join(\"\"),\n schema: paramsSchema,\n resolvedType: undefined,\n };\n\n const typesFileContent = render(typesFileTpl, {\n params,\n paramsSchema: paramsSchema.map((param, index) => {\n return {\n ...param,\n refinement: paramsRefinements?.at(index),\n };\n }),\n typeDeclarations,\n payloadTypes,\n responseTypes,\n });\n\n const resolvedTypes = resolveTypes\n ? literalTypesResolver(typesFileContent, {\n overrides: [...payloadTypes, ...responseTypes].reduce(\n (map: Record<string, string>, { id, skipValidation }) => {\n if (skipValidation) {\n map[id] = \"never\";\n }\n return map;\n },\n { [refineTypeName]: refineTypeName },\n ),\n withProperties: [params.id, ...payloadTypes.map((e) => e.id)],\n formatters,\n })\n : undefined;\n\n /**\n * Deploy types.ts file; required by core generators (like fetch).\n * If types resolved, write resolved types;\n * otherwise write original types extracted from API route.\n * */\n await renderToFile(\n typesFile,\n resolvedTypes ? resolvedTypesTpl : typesFileContent,\n { resolvedTypes },\n );\n\n params.resolvedType = resolvedTypes?.find(\n (e) => e.name === params.id,\n );\n\n cache = await persistCache({\n params,\n methods,\n typeDeclarations,\n numericParams,\n // text was needed at writing types.ts file, dropping from cache\n payloadTypes: payloadTypes.map(({ text, ...rest }) => {\n return {\n ...rest,\n resolvedType: resolvedTypes?.find((e) => e.name === rest.id),\n };\n }),\n responseTypes: responseTypes.map(({ text, ...rest }) => {\n return {\n ...rest,\n resolvedType: resolvedTypes?.find((e) => e.name === rest.id),\n };\n }),\n referencedFiles,\n });\n }\n\n const route: ApiRoute = {\n name,\n pathTokens,\n params: cache.params,\n numericParams: cache.numericParams,\n optionalParams,\n importName,\n importPath,\n folder,\n file,\n fileFullpath,\n methods: cache.methods,\n typeDeclarations: cache.typeDeclarations,\n payloadTypes: cache.payloadTypes,\n responseTypes: cache.responseTypes,\n referencedFiles: Object.keys(cache.referencedFiles).map(\n // expand referenced files path,\n // they are stored as relative in cache\n (e) => resolve(appRoot, e),\n ),\n };\n\n return {\n kind: \"api\",\n route,\n };\n };\n\n resolvers.set(fileFullpath, { name, handler });\n }\n\n for (const entry of entries.filter((e) => e.folder === defaults.pagesDir)) {\n const {\n //\n name,\n folder,\n file,\n fileFullpath,\n pathTokens,\n importPath,\n importName,\n } = entry;\n\n const handler: RouteResolver[\"handler\"] = async () => {\n const route: PageRoute = {\n name,\n pathTokens,\n params: {\n schema: pathTokens.flatMap((e) => (e.param ? [e.param] : [])),\n },\n folder,\n file,\n fileFullpath,\n importPath,\n importName,\n };\n\n return {\n kind: \"page\",\n route,\n };\n };\n\n resolvers.set(fileFullpath, { name, handler });\n }\n\n return resolvers;\n };\n\n const routeFiles = await glob(routeFilePatterns, {\n cwd: resolve(appRoot, sourceFolder),\n absolute: true,\n onlyFiles: true,\n ignore: [\n `${defaults.apiDir}/index.ts`,\n `${defaults.pagesDir}/index.ts{x,}`,\n ],\n });\n\n return {\n resolvers: resolversFactory(routeFiles),\n resolversFactory,\n resolveRouteFile,\n };\n};\n", "import { resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\nimport { flattener } from \"tfusion\";\nimport {\n type CallExpression,\n type Identifier,\n type Node,\n Project,\n type ProjectOptions,\n type SourceFile,\n SyntaxKind,\n} from \"ts-morph\";\n\nimport { type HTTPMethod, HTTPMethods } from \"@kosmojs/api\";\nimport type {\n ApiRoute,\n PayloadType,\n PluginOptionsResolved,\n ResponseType,\n TypeDeclaration,\n} from \"@kosmojs/devlib\";\n\ntype PathResolver = (path: string) => string;\n\nexport const createProject = (opts?: ProjectOptions) => new Project(opts);\n\nexport const resolveRouteSignature = async (\n route: Pick<ApiRoute, \"importName\" | \"fileFullpath\" | \"optionalParams\">,\n opts?: {\n relpathResolver?: PathResolver;\n sourceFile?: SourceFile;\n withReferencedFiles?: boolean;\n },\n) => {\n const {\n sourceFile = createProject().addSourceFileAtPath(route.fileFullpath),\n } = { ...opts };\n\n const [typeDeclarations, referencedFiles] = extractTypeDeclarations(\n sourceFile,\n opts,\n );\n\n const defaultExport = extractDefaultExport(sourceFile);\n\n const paramsRefinements = defaultExport\n ? extractParamsRefinements(defaultExport)\n : undefined;\n\n const methods = defaultExport\n ? extractRouteMethods(defaultExport, route)\n : [];\n\n const payloadTypes = methods.flatMap((e) => {\n return e.payloadType ? [e.payloadType] : [];\n });\n\n const responseTypes = methods.flatMap((e) => {\n return e.responseType ? [e.responseType] : [];\n });\n\n return {\n typeDeclarations,\n paramsRefinements,\n methods: methods.map((e) => e.method),\n payloadTypes,\n responseTypes,\n referencedFiles,\n };\n};\n\nexport const extractDefaultExport = (\n sourceFile: SourceFile,\n): CallExpression | undefined => {\n const [defaultExport] = sourceFile\n .getExportAssignments()\n .flatMap((exportAssignment) => {\n if (exportAssignment.isExportEquals()) {\n return [];\n }\n const callExpression = exportAssignment.getExpression();\n return callExpression.isKind(SyntaxKind.CallExpression)\n ? [callExpression]\n : [];\n });\n return defaultExport;\n};\n\nexport const extractParamsRefinements = (\n callExpression: CallExpression,\n):\n | Array<{\n index: number;\n text: string;\n }>\n | undefined => {\n const [firstGeneric] = extractGenerics(callExpression);\n\n if (!firstGeneric?.node.isKind(SyntaxKind.TupleType)) {\n return;\n }\n\n const tupleElements = firstGeneric.node.getElements();\n\n if (!tupleElements?.length) {\n return;\n }\n\n return tupleElements.map((node, index) => {\n return {\n index,\n text: node.getText(),\n };\n });\n};\n\nexport const extractRouteMethods = (\n callExpression: CallExpression,\n route: Pick<ApiRoute, \"importName\" | \"optionalParams\">,\n): Array<{\n method: HTTPMethod;\n payloadType: (PayloadType & { text: string }) | undefined;\n responseType: (ResponseType & { text: string }) | undefined;\n}> => {\n const funcDeclaration =\n callExpression.getFirstChildByKind(SyntaxKind.ArrowFunction) ||\n callExpression.getFirstChildByKind(SyntaxKind.FunctionExpression);\n\n if (!funcDeclaration) {\n return [];\n }\n\n const arrayLiteralExpression = funcDeclaration.getFirstChildByKind(\n SyntaxKind.ArrayLiteralExpression,\n );\n\n if (!arrayLiteralExpression) {\n return [];\n }\n\n const callExpressions: Array<[CallExpression, HTTPMethod]> = [];\n\n for (const e of arrayLiteralExpression.getChildrenOfKind(\n SyntaxKind.CallExpression,\n )) {\n const name = e.getExpression().getText() as HTTPMethod;\n if (HTTPMethods[name]) {\n callExpressions.push([e, name]);\n }\n }\n\n const methods = [];\n\n const skipValidationFilter = (e: string) => /@skip-validation/.test(e);\n\n for (const [callExpression, method] of callExpressions) {\n const [payloadGeneric, responseGeneric] = extractGenerics(callExpression);\n\n const payloadText = payloadGeneric?.node\n ? payloadGeneric.node.getChildren().length === 0\n ? \"{}\"\n : payloadGeneric.node.getFullText()\n : undefined;\n\n const responseText = responseGeneric?.node.getText();\n\n const responseType = responseText\n ? {\n id: [\"ResponseT\", crc(route.importName + method)].join(\"\"),\n method,\n skipValidation: responseGeneric?.comments\n ? responseGeneric.comments.some(skipValidationFilter)\n : false,\n text: [\"never\", \"object\"].includes(responseText)\n ? \"{}\"\n : responseText,\n resolvedType: undefined,\n }\n : undefined;\n\n const payloadType = payloadText\n ? {\n id: [\"PayloadT\", crc(route.importName + method)].join(\"\"),\n responseTypeId: responseType?.id,\n method,\n skipValidation: payloadGeneric?.comments\n ? payloadGeneric.comments.some(skipValidationFilter)\n : false,\n isOptional: payloadText\n ? payloadText === \"{}\" || route.optionalParams\n : true,\n text: payloadText,\n resolvedType: undefined,\n }\n : undefined;\n\n methods.push({\n method,\n payloadType,\n responseType,\n });\n }\n\n return methods;\n};\n\nexport const extractTypeDeclarations = (\n sourceFile: SourceFile,\n opts?: {\n relpathResolver?: PathResolver;\n withReferencedFiles?: boolean;\n },\n): [d: Array<TypeDeclaration>, f?: Array<string>] => {\n const declarations: Array<TypeDeclaration> = [];\n\n const referencedFiles: Array<string> | undefined = opts?.withReferencedFiles\n ? []\n : undefined;\n\n for (const declaration of sourceFile.getImportDeclarations()) {\n const modulePath = declaration.getModuleSpecifierValue();\n\n const path = /^\\.\\.?\\/?/.test(modulePath)\n ? opts?.relpathResolver\n ? opts.relpathResolver(modulePath)\n : modulePath\n : modulePath;\n\n const typeOnlyDeclaration = declaration.isTypeOnly();\n\n const defaultImport = typeOnlyDeclaration\n ? declaration.getDefaultImport()\n : undefined;\n\n if (defaultImport) {\n const name = defaultImport.getText();\n const text = `import type ${name} from \"${path}\";`;\n declarations.push({\n importDeclaration: {\n name,\n path,\n },\n text,\n });\n if (referencedFiles) {\n referencedFiles.push(...getReferencedFiles(defaultImport));\n }\n }\n\n for (const namedImport of declaration.getNamedImports()) {\n if (namedImport.isTypeOnly() || typeOnlyDeclaration) {\n const nameNode = namedImport.getNameNode();\n const name = nameNode.getText();\n const alias = namedImport.getAliasNode()?.getText();\n const nameText = alias ? `${name} as ${alias}` : name;\n\n declarations.push({\n importDeclaration: {\n name,\n alias,\n path,\n },\n text: `import type { ${nameText} } from \"${path}\";`,\n });\n\n if (referencedFiles) {\n if (nameNode.isKind(SyntaxKind.Identifier)) {\n referencedFiles.push(...getReferencedFiles(nameNode));\n }\n }\n }\n }\n }\n\n for (const declaration of sourceFile.getTypeAliases()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n typeAliasDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getInterfaces()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n interfaceDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getEnums()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n enumDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getExportDeclarations()) {\n const typeOnlyDeclaration = declaration.isTypeOnly();\n\n const modulePath = declaration.getModuleSpecifierValue();\n\n const path = modulePath\n ? /^\\.\\.?\\/?/.test(modulePath)\n ? opts?.relpathResolver\n ? opts.relpathResolver(modulePath)\n : modulePath\n : modulePath\n : undefined;\n\n for (const namedExport of declaration.getNamedExports()) {\n if (namedExport.isTypeOnly() || typeOnlyDeclaration) {\n const nameNode = namedExport.getNameNode();\n const name = nameNode.getText();\n const alias = namedExport.getAliasNode()?.getText();\n const nameText = alias ? `${name} as ${alias}` : name;\n\n declarations.push({\n exportDeclaration: {\n name,\n alias: alias ?? name,\n path,\n },\n text: path\n ? `export type { ${nameText} } from \"${path}\";`\n : `export type { ${nameText} };`,\n });\n\n if (referencedFiles) {\n if (nameNode.isKind(SyntaxKind.Identifier)) {\n referencedFiles.push(...getReferencedFiles(nameNode));\n }\n }\n }\n }\n }\n\n return referencedFiles\n ? [declarations, [...new Set<string>(referencedFiles)]]\n : [declarations];\n};\n\nconst getReferencedFiles = (importIdentifier: Identifier): Array<string> => {\n // ambient modules may have declarations in multiple files\n const declarations =\n importIdentifier //\n ?.getSymbol()\n ?.getAliasedSymbol()\n ?.getDeclarations() || [];\n\n return declarations.flatMap((e) => {\n const sourceFile = e.getSourceFile();\n return sourceFile //\n ? [sourceFile.getFilePath()]\n : [];\n });\n};\n\nconst extractGenerics = (\n callExpression: CallExpression,\n): Array<{ node: Node; comments: Array<string> }> => {\n return callExpression.getTypeArguments().map((node) => {\n return {\n node,\n comments: node\n .getLeadingCommentRanges()\n .map((range) => range.getText().trim()),\n };\n });\n};\n\nexport const typeResolverFactory = ({ appRoot }: PluginOptionsResolved) => {\n const project = createProject({\n tsConfigFilePath: resolve(appRoot, \"tsconfig.json\"),\n skipAddingFilesFromTsConfig: true,\n });\n\n const literalTypesResolver = (\n literalTypes: string,\n options: Parameters<typeof flattener>[2],\n ) => {\n const sourceFile = project.createSourceFile(\n `${crc(literalTypes)}-${Date.now()}.ts`,\n literalTypes,\n { overwrite: true },\n );\n\n const resolvedTypes = flattener(project, sourceFile, {\n ...options,\n stripComments: true,\n });\n\n project.removeSourceFile(sourceFile);\n\n return resolvedTypes;\n };\n\n return {\n getSourceFile: (fileFullpath: string) => {\n return (\n project.getSourceFile(fileFullpath) ||\n project.addSourceFileAtPath(fileFullpath)\n );\n },\n refreshSourceFile: async (fileFullpath: string) => {\n const sourceFile = project.getSourceFile(fileFullpath);\n if (sourceFile) {\n await sourceFile.refreshFromFileSystem();\n }\n },\n literalTypesResolver,\n };\n};\n", "import { mkdir, readFile, writeFile } from \"node:fs/promises\";\nimport { dirname, resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\n\n/**\n * Import from published package to ensure correct version at runtime.\n * Local import would be bundled with pre-bump version; this external\n * import resolves to the actual published package.json.\n * */\nimport self from \"@kosmojs/dev/package.json\" with { type: \"json\" };\nimport { type ApiRoute, pathExists, pathResolver } from \"@kosmojs/devlib\";\n\nexport type Cache = {\n hash: number;\n referencedFiles: Record<string, number>;\n} & Pick<\n ApiRoute,\n | \"params\"\n | \"methods\"\n | \"typeDeclarations\"\n | \"numericParams\"\n | \"payloadTypes\"\n | \"responseTypes\"\n>;\n\ntype ExtraContext = Record<string | number, unknown>;\n\nexport const cacheFactory = (\n route: Pick<ApiRoute, \"file\" | \"fileFullpath\" | \"importName\" | \"importPath\">,\n {\n appRoot,\n sourceFolder,\n extraContext,\n }: {\n appRoot: string;\n sourceFolder: string;\n extraContext?: ExtraContext;\n },\n) => {\n const cacheFile = pathResolver({\n appRoot,\n sourceFolder,\n }).resolve(\"apiLibDir\", route.importPath, \"cache.json\");\n\n const getCache = async (opt?: {\n validate?: boolean;\n }): Promise<Cache | undefined> => {\n if (await pathExists(cacheFile)) {\n try {\n const cache = JSON.parse(await readFile(cacheFile, \"utf8\"));\n return opt?.validate //\n ? validateCache(cache)\n : cache;\n } catch (_e) {}\n }\n return undefined;\n };\n\n const persistCache = async ({\n referencedFiles: _referencedFiles,\n ...rest\n }: Omit<Cache, \"hash\" | \"referencedFiles\"> & {\n referencedFiles: Array<string>;\n }): Promise<Cache> => {\n const hash = await generateFileHash(route.fileFullpath, {\n ...extraContext,\n });\n\n const referencedFiles: Cache[\"referencedFiles\"] = {};\n\n for (const file of _referencedFiles) {\n referencedFiles[\n // Strip project root to ensure cached paths are relative\n // and portable across environments (CI, local, etc.)\n file.replace(`${appRoot}/`, \"\")\n ] = await generateFileHash(file);\n }\n\n const cache = { ...rest, hash, referencedFiles };\n\n await mkdir(dirname(cacheFile), { recursive: true });\n await writeFile(cacheFile, JSON.stringify(cache, null, 2), \"utf8\");\n\n return cache;\n };\n\n const validateCache = async (\n cache: Cache | undefined,\n ): Promise<Cache | undefined> => {\n if (!cache?.hash) {\n return;\n }\n\n if (!cache.typeDeclarations || !cache.referencedFiles) {\n // incomplete cache\n return;\n }\n\n const hash = await generateFileHash(route.fileFullpath, {\n ...extraContext,\n });\n\n if (!identicalHashSum(cache.hash, hash)) {\n // route itself updated\n return;\n }\n\n for (const [file, hash] of Object.entries(cache.referencedFiles)) {\n if (\n !identicalHashSum(hash, await generateFileHash(resolve(appRoot, file)))\n ) {\n // some referenced file updated\n return;\n }\n }\n\n return cache;\n };\n\n return {\n getCache,\n validateCache,\n persistCache,\n };\n};\n\nconst generateFileHash = async (\n file: string,\n extraContext?: ExtraContext,\n): Promise<number> => {\n let fileContent: string | undefined;\n try {\n fileContent = await readFile(file, \"utf8\");\n } catch (_e) {\n // file could be deleted since last build\n return 0;\n }\n return fileContent\n ? crc(\n JSON.stringify({\n ...extraContext,\n [self.cacheVersion]: fileContent,\n }),\n )\n : 0;\n};\n\n// return true if sums are identical\nconst identicalHashSum = (a: number, b: number) => {\n return a === b;\n};\n", "{{#each resolvedTypes}}\nexport type {{name}} = {{text}};\n{{/each}}\n", "{{#each typeDeclarations}}{{text}}\n{{/each}}\n\nexport type {{params.id}} = {\n {{#each paramsSchema}}\n \"{{name}}\"{{#unless isRequired}}?{{/unless}}:{{#if isRest}} Array<{{/if}}\n {{#if refinement}}{{refinement.text}}{{else}}string{{/if}}\n {{#if isRest}}>{{/if}}\n {{/each}}\n};\n\n{{#each payloadTypes}}\nexport type {{id}} = {{text}};\n{{/each}}\n\n{{#each responseTypes}}\nexport type {{id}} = {{text}};\n{{/each}}\n"],
5
- "mappings": "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",
6
- "names": ["crc", "pathResolver", "dirname", "resolve", "crc", "pathResolver", "callExpression", "appRoot", "resolve", "crc", "appRoot", "sourceFolder", "hash", "appRoot", "sourceFolder", "generators", "formatters", "resolveRouteFile", "resolve", "resolversFactory", "routeFiles", "resolvers", "dirname", "crc", "pathResolver", "resolve", "pathResolver", "crc"]
3
+ "sources": ["../../src/base-plugin/worker.ts", "../../src/base-plugin/routes.ts", "../../src/base-plugin/routes/resolve.ts", "../../src/base-plugin/ast.ts", "../../src/base-plugin/cache.ts", "../../src/base-plugin/templates/resolved-types.hbs", "../../src/base-plugin/templates/types.hbs", "../../src/base-plugin/routes/nesting.ts"],
4
+ "sourcesContent": ["import { parentPort, workerData } from \"node:worker_threads\";\n\nimport chokidar from \"chokidar\";\nimport crc from \"crc/crc32\";\n\nimport {\n type Formatter,\n type GeneratorConstructor,\n type PluginOptionsResolved,\n pathResolver,\n type ResolvedEntry,\n type WatcherEvent,\n type WatchHandler,\n} from \"@kosmojs/devlib\";\n\nimport routesFactory, { isRouteFile, type ResolverSignature } from \"./routes\";\nimport type { SpinnerFactory } from \"./spinner\";\n\nexport type WorkerData = Omit<\n PluginOptionsResolved,\n \"generators\" | \"formatters\"\n> & {\n generatorModules: Array<[string, unknown]>;\n formatterModules: Array<[string, unknown]>;\n};\n\nexport type WorkerSpinner = {\n id: string;\n startText: string;\n method: keyof SpinnerFactory;\n text?: string | undefined;\n};\n\nexport type WorkerError = {\n name: string;\n message: string;\n stack?: string;\n};\n\nconst {\n //\n generatorModules,\n formatterModules,\n ...restOptions\n} = workerData as WorkerData;\n\nconst generators: Array<GeneratorConstructor> = [];\nconst formatters: Array<Formatter> = [];\n\nfor (const [path, opts] of generatorModules) {\n generators.push(await import(path).then((m) => m.default(opts)));\n}\n\nfor (const [path, opts] of formatterModules) {\n formatters.push(await import(path).then((m) => m.default(opts).formatter));\n}\n\nconst resolvedOptions: PluginOptionsResolved = {\n ...restOptions,\n generators,\n formatters,\n};\n\nconst { appRoot, sourceFolder } = resolvedOptions;\n\nconst watchHandlers: Array<{ name: string; handler: WatchHandler }> = [];\n\nconst resolvedEntries = new Map<\n string, // fileFullpath\n ResolvedEntry\n>();\n\nconst { resolvers, resolversFactory } = await routesFactory(resolvedOptions);\n\nconst { resolve } = pathResolver({ appRoot, sourceFolder });\n\nconst spinnerFactory = (startText: string) => {\n const id = [startText, Date.now().toString()].map(crc).join(\":\");\n\n const postMessage = (\n method: keyof SpinnerFactory,\n text?: string | undefined,\n ) => {\n const spinner: WorkerSpinner = { id, startText, method, text };\n parentPort?.postMessage({ spinner });\n };\n\n const postError = (error: Error) => {\n parentPort?.postMessage({ error: structuredClone(error) });\n };\n\n return {\n id,\n startText,\n text(text: string) {\n postMessage(\"text\", text);\n },\n append(text: string) {\n postMessage(\"append\", text);\n },\n succeed(text?: string) {\n postMessage(\"succeed\", text);\n },\n failed(error: Error) {\n postError(error);\n postMessage(\"failed\", error?.stack || error?.message);\n },\n };\n};\n\nconst createEventHandler = async (file: string) => {\n const [resolver] = resolversFactory([file]).values();\n if (resolver) {\n const spinner = spinnerFactory(`Resolving ${resolver.name} Route`);\n try {\n const resolvedEntry = await resolver.handler();\n resolvers.set(file, resolver);\n resolvedEntries.set(resolvedEntry.entry.fileFullpath, resolvedEntry);\n spinner.succeed();\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n }\n }\n};\n\nconst updateEventHandler = async (file: string) => {\n const relatedResolvers = new Map<\n string, // fileFullpath\n ResolverSignature\n >();\n\n if (resolvedEntries.has(file)) {\n // some route updated\n const resolver = resolvers.get(file);\n if (resolver) {\n relatedResolvers.set(file, resolver);\n }\n } else {\n // checking if changed file is referenced by any routes\n const referencedRoutes = resolvedEntries\n .values()\n .flatMap(({ kind, entry }) => {\n return kind === \"apiRoute\"\n ? entry.referencedFiles.includes(file)\n ? [entry]\n : []\n : [];\n });\n for (const route of referencedRoutes) {\n const resolver = resolvers.get(route.fileFullpath);\n if (resolver) {\n relatedResolvers.set(route.fileFullpath, resolver);\n }\n }\n }\n\n let spinner = spinnerFactory(`Updating ${relatedResolvers.size} Routes`);\n\n for (const resolver of relatedResolvers.values()) {\n spinner.append(resolver.name);\n try {\n const resolvedEntry = await resolver.handler(file);\n resolvedEntries.set(resolvedEntry.entry.fileFullpath, resolvedEntry);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(`Updating ${relatedResolvers.size} Routes`);\n }\n }\n\n spinner.succeed();\n};\n\nconst deleteEventHandler = async () => {\n // TODO: cleanup related files in libDir\n};\n\nconst runWatchHandlers = async (event?: WatcherEvent) => {\n let spinner = spinnerFactory(\"Running Generators\");\n\n /**\n * Watch handlers receive the full list of entries\n * and should process only those whose source file or dependencies were updated.\n */\n const entries = Array.from(resolvedEntries.values());\n\n for (const { name, handler } of watchHandlers) {\n spinner.append(name);\n try {\n // using structuredClone to make sure no generator would alter routes\n await handler(structuredClone(entries), event);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Running Generators\");\n }\n }\n\n spinner.succeed();\n};\n\nconst watcher = chokidar.watch(\n [\n // watching for changes in sourceFolder's apiDir and pagesDir\n resolve(\"apiDir\"),\n resolve(\"pagesDir\"),\n ],\n {\n ...resolvedOptions.watcher.options,\n awaitWriteFinish:\n typeof resolvedOptions.watcher.options?.awaitWriteFinish === \"object\"\n ? resolvedOptions.watcher.options.awaitWriteFinish\n : {\n stabilityThreshold: resolvedOptions.watcher.delay,\n pollInterval: Math.floor(resolvedOptions.watcher.delay / 4),\n },\n // Do Not emit \"add\" event for existing files\n ignoreInitial: true,\n // Not using Chokidar's `ignored` option.\n // Instead, allow all events through and filter them manually as needed.\n },\n);\n\nwatcher.on(\"all\", async (event, file) => {\n if (event.endsWith(\"Dir\")) {\n // skipping folder events\n return;\n }\n\n if (!isRouteFile(file, { appRoot, sourceFolder })) {\n // not a route file\n return;\n }\n\n const match = (\n {\n add: { handler: createEventHandler, kind: \"create\" },\n change: { handler: updateEventHandler, kind: \"update\" },\n unlink: { handler: deleteEventHandler, kind: \"delete\" },\n } as const\n )[event as string];\n\n if (match) {\n const { handler, kind } = match;\n\n /**\n * This handler is responsible for updating `resolvedRoutes`\n * before they are passed to generators.\n * */\n await handler(file);\n\n await runWatchHandlers({ kind, file });\n }\n});\n\n{\n let spinner = spinnerFactory(\"Resolving Routes\");\n\n for (const { name, handler } of resolvers.values()) {\n spinner.append(\n `[ ${resolvedEntries.size + 1} of ${resolvers.size} ] ${name}`,\n );\n try {\n const resolvedEntry = await handler();\n resolvedEntries.set(resolvedEntry.entry.fileFullpath, resolvedEntry);\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Resolving Routes\");\n }\n }\n\n spinner.succeed();\n}\n\n{\n let spinner = spinnerFactory(\"Initializing Generators\");\n\n for (const { name, factory } of generators) {\n spinner.append(name);\n try {\n const { watchHandler } = await factory(resolvedOptions);\n watchHandlers.push({ name, handler: watchHandler });\n } catch (\n // biome-ignore lint: any\n error: any\n ) {\n spinner.failed(error);\n spinner = spinnerFactory(\"Initializing Generators\");\n }\n }\n\n spinner.succeed();\n}\n\nawait runWatchHandlers();\n\nparentPort?.postMessage(\"ready\");\n", "import {\n defaults,\n type PluginOptionsResolved,\n type RouteEntry,\n} from \"@kosmojs/devlib\";\n\nimport {\n apiRouteResolverFactory,\n createRouteEntry,\n isPageFile,\n pageLayoutResolverFactory,\n pageRouteResolverFactory,\n type ResolverSignature,\n scanRoutes,\n} from \"./routes/resolve\";\n\nexport * from \"./routes/nesting\";\nexport * from \"./routes/resolve\";\n\nexport default async (pluginOptions: PluginOptionsResolved) => {\n const { appRoot, sourceFolder } = pluginOptions;\n\n const apiRouteResolver = apiRouteResolverFactory(pluginOptions);\n const pageRouteResolver = pageRouteResolverFactory(pluginOptions);\n const pageLayoutResolver = pageLayoutResolverFactory(pluginOptions);\n\n const resolversFactory = (routeFiles: Array<string>) => {\n const resolvers = new Map<\n string, // fileFullpath\n ResolverSignature\n >();\n\n const entries: Array<RouteEntry> = routeFiles.flatMap((file) => {\n const entry = createRouteEntry(file, pluginOptions);\n return entry ? [entry] : [];\n });\n\n for (const entry of entries) {\n if (entry.folder === defaults.apiDir) {\n resolvers.set(entry.fileFullpath, apiRouteResolver(entry));\n } else if (entry.folder === defaults.pagesDir) {\n const pageFile = isPageFile(entry.file);\n if (pageFile?.kind === \"index\") {\n resolvers.set(entry.fileFullpath, pageRouteResolver(entry));\n } else if (pageFile?.kind === \"layout\") {\n resolvers.set(entry.fileFullpath, pageLayoutResolver(entry));\n }\n }\n }\n\n return resolvers;\n };\n\n const routeFiles = await scanRoutes({ appRoot, sourceFolder });\n\n return {\n resolvers: resolversFactory(routeFiles),\n resolversFactory,\n };\n};\n", "import { dirname, join, resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\nimport picomatch from \"picomatch\";\nimport { glob } from \"tinyglobby\";\n\nimport {\n type ApiRoute,\n defaults,\n type PageRoute,\n type PluginOptionsResolved,\n pathResolver,\n pathTokensFactory,\n type ResolvedEntry,\n type RouteEntry,\n render,\n renderToFile,\n} from \"@kosmojs/devlib\";\n\nimport { resolveRouteSignature, typeResolverFactory } from \"../ast\";\nimport { cacheFactory } from \"../cache\";\nimport resolvedTypesTpl from \"../templates/resolved-types.hbs\";\nimport typesFileTpl from \"../templates/types.hbs\";\n\nexport type ResolverSignature = {\n name: string;\n handler: (updatedFile?: string) => Promise<ResolvedEntry>;\n};\n\nexport const API_INDEX_BASENAME = \"index\";\nexport const API_INDEX_PATTERN = `${API_INDEX_BASENAME}.ts`;\n\nexport const PAGE_INDEX_BASENAME = \"index\";\nexport const PAGE_INDEX_PATTERN = `${PAGE_INDEX_BASENAME}.{tsx,vue}`;\n\nexport const PAGE_LAYOUT_BASENAME = \"layout\";\nexport const PAGE_LAYOUT_PATTERN = `${PAGE_LAYOUT_BASENAME}.{tsx,vue}`;\n\nconst ROUTE_FILE_PATTERNS = [\n // match index files in api dir\n `${defaults.apiDir}/**/${API_INDEX_PATTERN}`,\n // match index files in pages dir\n `${defaults.pagesDir}/**/${PAGE_INDEX_PATTERN}`,\n // match layout files in pages dir\n `${defaults.pagesDir}/**/${PAGE_LAYOUT_PATTERN}`,\n];\n\nexport const scanRoutes = async ({\n appRoot,\n sourceFolder,\n}: Pick<PluginOptionsResolved, \"appRoot\" | \"sourceFolder\">) => {\n return glob(ROUTE_FILE_PATTERNS, {\n cwd: resolve(appRoot, sourceFolder),\n absolute: true,\n onlyFiles: true,\n followSymbolicLinks: false,\n ignore: [\n // ignore top-level matches, routes resides in folders, even index route\n `${defaults.apiDir}/${API_INDEX_PATTERN}`,\n `${defaults.pagesDir}/${PAGE_INDEX_PATTERN}`,\n `${defaults.pagesDir}/${PAGE_LAYOUT_PATTERN}`,\n ],\n });\n};\n\nexport const isRouteFile = (\n file: string,\n {\n appRoot,\n sourceFolder,\n }: Pick<PluginOptionsResolved, \"appRoot\" | \"sourceFolder\">,\n):\n | [\n // Either `apiDir` or `pagesDir`\n folder: string,\n // Path to a file within the folder, nested at least one level deep\n file: string,\n ]\n | undefined => {\n const [_sourceFolder, folder, ...rest] = resolve(appRoot, file)\n .replace(`${appRoot}/`, \"\")\n .split(\"/\");\n\n /**\n * Ensure the file:\n * - is under the correct source root (`sourceFolder`)\n * - belongs to a known route folder (`apiDir` or `pagesDir`)\n * - is nested at least one level deep (not a direct child of the folder)\n * */\n if (!folder || _sourceFolder !== sourceFolder || rest.length < 2) {\n return;\n }\n\n return picomatch.isMatch(join(folder, ...rest), ROUTE_FILE_PATTERNS)\n ? [folder, rest.join(\"/\")]\n : undefined;\n};\n\nexport const isPageFile = (\n file: string,\n): { kind: \"index\" | \"layout\" } | undefined => {\n return picomatch.matchBase(file, `**/${PAGE_INDEX_PATTERN}`)\n ? { kind: \"index\" }\n : picomatch.matchBase(file, `**/${PAGE_LAYOUT_PATTERN}`)\n ? { kind: \"layout\" }\n : undefined;\n};\n\nexport const isIndexFile = (file: string) => {\n return (\n picomatch.matchBase(file, `**/${API_INDEX_PATTERN}`) ||\n picomatch.matchBase(file, `**/${PAGE_INDEX_PATTERN}`)\n );\n};\n\nexport const createRouteEntry = (\n _file: string,\n {\n appRoot,\n sourceFolder,\n }: Pick<PluginOptionsResolved, \"appRoot\" | \"sourceFolder\">,\n): RouteEntry | undefined => {\n // scanner already is doing a great job on matching only relevant files\n // but doing a double check here to make sure only needed files added to stack\n const resolvedPaths = isRouteFile(_file, { appRoot, sourceFolder });\n\n if (!resolvedPaths) {\n return;\n }\n\n const [folder, file] = resolvedPaths;\n\n const fileFullpath = join(appRoot, sourceFolder, folder, file);\n\n const pathTokens = pathTokensFactory(dirname(file));\n\n const name = pathTokens.map((e) => e.orig).join(\"/\");\n\n const importFile = file;\n\n const importName = `${importFile.replace(/\\W+/g, \"_\")}_${crc(importFile)}`;\n\n return {\n name,\n folder,\n file,\n fileFullpath,\n pathTokens,\n importFile,\n importName,\n };\n};\n\ntype ResolverFactory = (\n pluginOptions: PluginOptionsResolved,\n) => (entry: RouteEntry) => ResolverSignature;\n\nexport const pageLayoutResolverFactory: ResolverFactory = () => {\n return (entry) => {\n const { name } = entry;\n\n const handler: ResolverSignature[\"handler\"] = async () => {\n return {\n kind: \"pageLayout\",\n entry,\n };\n };\n\n return { name, handler };\n };\n};\n\nexport const pageRouteResolverFactory: ResolverFactory = () => {\n return (entry) => {\n const {\n name,\n folder,\n file,\n fileFullpath,\n pathTokens,\n importFile,\n importName,\n } = entry;\n\n const handler: ResolverSignature[\"handler\"] = async () => {\n const entry: PageRoute = {\n name,\n pathTokens,\n params: {\n schema: pathTokens.flatMap((e) => (e.param ? [e.param] : [])),\n },\n folder,\n file,\n fileFullpath,\n importFile,\n importName,\n };\n\n return {\n kind: \"pageRoute\",\n entry,\n };\n };\n\n return { name, handler };\n };\n};\n\nexport const apiRouteResolverFactory: ResolverFactory = (pluginOptions) => {\n const {\n appRoot,\n sourceFolder,\n generators = [],\n formatters = [],\n refineTypeName,\n } = pluginOptions;\n\n let resolveTypes = false;\n\n for (const { options } of generators) {\n if (options?.resolveTypes) {\n resolveTypes = true;\n }\n }\n\n const {\n //\n literalTypesResolver,\n getSourceFile,\n refreshSourceFile,\n } = typeResolverFactory(pluginOptions);\n\n return (entry) => {\n const {\n name,\n file,\n folder,\n fileFullpath,\n pathTokens,\n importFile,\n importName,\n } = entry;\n\n const handler: ResolverSignature[\"handler\"] = async (updatedFile) => {\n const paramsSchema = pathTokens.flatMap((e) => {\n return e.param ? [e.param] : [];\n });\n\n const optionalParams = paramsSchema.length\n ? !paramsSchema.some((e) => e.isRequired)\n : true;\n\n const { getCache, persistCache } = cacheFactory(\n { file, fileFullpath, importName },\n {\n appRoot,\n sourceFolder,\n extraContext: { resolveTypes },\n },\n );\n\n let cache = await getCache({ validate: true });\n\n if (!cache) {\n if (updatedFile === fileFullpath) {\n await refreshSourceFile(fileFullpath);\n }\n\n const {\n typeDeclarations,\n paramsRefinements,\n methods,\n payloadTypes,\n responseTypes,\n referencedFiles = [],\n } = await resolveRouteSignature(\n { importName, fileFullpath, optionalParams },\n {\n withReferencedFiles: true,\n sourceFile: getSourceFile(fileFullpath),\n relpathResolver(path) {\n return join(sourceFolder, defaults.apiDir, dirname(file), path);\n },\n },\n );\n\n const numericParams = paramsRefinements\n ? paramsRefinements.flatMap(({ text, index }) => {\n if (text === \"number\") {\n const param = paramsSchema.at(index);\n return param ? [param.name] : [];\n }\n return [];\n })\n : [];\n\n const typesFile = pathResolver({ appRoot, sourceFolder }).resolve(\n \"apiLibDir\",\n dirname(file),\n \"types.ts\",\n );\n\n const params: ApiRoute[\"params\"] = {\n id: [\"ParamsT\", crc(name)].join(\"\"),\n schema: paramsSchema,\n resolvedType: undefined,\n };\n\n const typesFileContent = render(typesFileTpl, {\n params,\n paramsSchema: paramsSchema.map((param, index) => {\n return {\n ...param,\n refinement: paramsRefinements?.at(index),\n };\n }),\n typeDeclarations,\n payloadTypes,\n responseTypes,\n });\n\n const resolvedTypes = resolveTypes\n ? literalTypesResolver(typesFileContent, {\n overrides: [...payloadTypes, ...responseTypes].reduce(\n (map: Record<string, string>, { id, skipValidation }) => {\n if (skipValidation) {\n map[id] = \"never\";\n }\n return map;\n },\n { [refineTypeName]: refineTypeName },\n ),\n withProperties: [params.id, ...payloadTypes.map((e) => e.id)],\n formatters,\n })\n : undefined;\n\n /**\n * Deploy types.ts file; required by core generators (like fetch).\n * If types resolved, write resolved types;\n * otherwise write original types extracted from API route.\n * */\n await renderToFile(\n typesFile,\n resolvedTypes ? resolvedTypesTpl : typesFileContent,\n { resolvedTypes },\n );\n\n params.resolvedType = resolvedTypes?.find((e) => e.name === params.id);\n\n cache = await persistCache({\n params,\n methods,\n typeDeclarations,\n numericParams,\n // text was needed at writing types.ts file, dropping from cache\n payloadTypes: payloadTypes.map(({ text, ...rest }) => {\n return {\n ...rest,\n resolvedType: resolvedTypes?.find((e) => e.name === rest.id),\n };\n }),\n responseTypes: responseTypes.map(({ text, ...rest }) => {\n return {\n ...rest,\n resolvedType: resolvedTypes?.find((e) => e.name === rest.id),\n };\n }),\n referencedFiles,\n });\n }\n\n const entry: ApiRoute = {\n name,\n pathTokens,\n params: cache.params,\n numericParams: cache.numericParams,\n optionalParams,\n importName,\n importFile,\n folder,\n file,\n fileFullpath,\n methods: cache.methods,\n typeDeclarations: cache.typeDeclarations,\n payloadTypes: cache.payloadTypes,\n responseTypes: cache.responseTypes,\n referencedFiles: Object.keys(cache.referencedFiles).map(\n // expand referenced files path,\n // they are stored as relative in cache\n (e) => resolve(appRoot, e),\n ),\n };\n\n return {\n kind: \"apiRoute\",\n entry,\n };\n };\n\n return { name, handler };\n };\n};\n", "import { resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\nimport { flattener } from \"tfusion\";\nimport {\n type CallExpression,\n type Identifier,\n type Node,\n Project,\n type ProjectOptions,\n type SourceFile,\n SyntaxKind,\n} from \"ts-morph\";\n\nimport { type HTTPMethod, HTTPMethods } from \"@kosmojs/api\";\nimport type {\n ApiRoute,\n PayloadType,\n PluginOptionsResolved,\n ResponseType,\n TypeDeclaration,\n} from \"@kosmojs/devlib\";\n\ntype PathResolver = (path: string) => string;\n\nexport const createProject = (opts?: ProjectOptions) => new Project(opts);\n\nexport const resolveRouteSignature = async (\n route: Pick<ApiRoute, \"importName\" | \"fileFullpath\" | \"optionalParams\">,\n opts?: {\n relpathResolver?: PathResolver;\n sourceFile?: SourceFile;\n withReferencedFiles?: boolean;\n },\n) => {\n const {\n sourceFile = createProject().addSourceFileAtPath(route.fileFullpath),\n } = { ...opts };\n\n const [typeDeclarations, referencedFiles] = extractTypeDeclarations(\n sourceFile,\n opts,\n );\n\n const defaultExport = extractDefaultExport(sourceFile);\n\n const paramsRefinements = defaultExport\n ? extractParamsRefinements(defaultExport)\n : undefined;\n\n const methods = defaultExport\n ? extractRouteMethods(defaultExport, route)\n : [];\n\n const payloadTypes = methods.flatMap((e) => {\n return e.payloadType ? [e.payloadType] : [];\n });\n\n const responseTypes = methods.flatMap((e) => {\n return e.responseType ? [e.responseType] : [];\n });\n\n return {\n typeDeclarations,\n paramsRefinements,\n methods: methods.map((e) => e.method),\n payloadTypes,\n responseTypes,\n referencedFiles,\n };\n};\n\nexport const extractDefaultExport = (\n sourceFile: SourceFile,\n): CallExpression | undefined => {\n const [defaultExport] = sourceFile\n .getExportAssignments()\n .flatMap((exportAssignment) => {\n if (exportAssignment.isExportEquals()) {\n return [];\n }\n const callExpression = exportAssignment.getExpression();\n return callExpression.isKind(SyntaxKind.CallExpression)\n ? [callExpression]\n : [];\n });\n return defaultExport;\n};\n\nexport const extractParamsRefinements = (\n callExpression: CallExpression,\n):\n | Array<{\n index: number;\n text: string;\n }>\n | undefined => {\n const [firstGeneric] = extractGenerics(callExpression);\n\n if (!firstGeneric?.node.isKind(SyntaxKind.TupleType)) {\n return;\n }\n\n const tupleElements = firstGeneric.node.getElements();\n\n if (!tupleElements?.length) {\n return;\n }\n\n return tupleElements.map((node, index) => {\n return {\n index,\n text: node.getText(),\n };\n });\n};\n\nexport const extractRouteMethods = (\n callExpression: CallExpression,\n route: Pick<ApiRoute, \"importName\" | \"optionalParams\">,\n): Array<{\n method: HTTPMethod;\n payloadType: (PayloadType & { text: string }) | undefined;\n responseType: (ResponseType & { text: string }) | undefined;\n}> => {\n const funcDeclaration =\n callExpression.getFirstChildByKind(SyntaxKind.ArrowFunction) ||\n callExpression.getFirstChildByKind(SyntaxKind.FunctionExpression);\n\n if (!funcDeclaration) {\n return [];\n }\n\n const arrayLiteralExpression = funcDeclaration.getFirstChildByKind(\n SyntaxKind.ArrayLiteralExpression,\n );\n\n if (!arrayLiteralExpression) {\n return [];\n }\n\n const callExpressions: Array<[CallExpression, HTTPMethod]> = [];\n\n for (const e of arrayLiteralExpression.getChildrenOfKind(\n SyntaxKind.CallExpression,\n )) {\n const name = e.getExpression().getText() as HTTPMethod;\n if (HTTPMethods[name]) {\n callExpressions.push([e, name]);\n }\n }\n\n const methods = [];\n\n const skipValidationFilter = (e: string) => /@skip-validation/.test(e);\n\n for (const [callExpression, method] of callExpressions) {\n const [payloadGeneric, responseGeneric] = extractGenerics(callExpression);\n\n const payloadText = payloadGeneric?.node\n ? payloadGeneric.node.getChildren().length === 0\n ? \"{}\"\n : payloadGeneric.node.getFullText()\n : undefined;\n\n const responseText = responseGeneric?.node.getText();\n\n const responseType = responseText\n ? {\n id: [\"ResponseT\", crc(route.importName + method)].join(\"\"),\n method,\n skipValidation: responseGeneric?.comments\n ? responseGeneric.comments.some(skipValidationFilter)\n : false,\n text: [\"never\", \"object\"].includes(responseText)\n ? \"{}\"\n : responseText,\n resolvedType: undefined,\n }\n : undefined;\n\n const payloadType = payloadText\n ? {\n id: [\"PayloadT\", crc(route.importName + method)].join(\"\"),\n responseTypeId: responseType?.id,\n method,\n skipValidation: payloadGeneric?.comments\n ? payloadGeneric.comments.some(skipValidationFilter)\n : false,\n isOptional: payloadText\n ? payloadText === \"{}\" || route.optionalParams\n : true,\n text: payloadText,\n resolvedType: undefined,\n }\n : undefined;\n\n methods.push({\n method,\n payloadType,\n responseType,\n });\n }\n\n return methods;\n};\n\nexport const extractTypeDeclarations = (\n sourceFile: SourceFile,\n opts?: {\n relpathResolver?: PathResolver;\n withReferencedFiles?: boolean;\n },\n): [d: Array<TypeDeclaration>, f?: Array<string>] => {\n const declarations: Array<TypeDeclaration> = [];\n\n const referencedFiles: Array<string> | undefined = opts?.withReferencedFiles\n ? []\n : undefined;\n\n for (const declaration of sourceFile.getImportDeclarations()) {\n const modulePath = declaration.getModuleSpecifierValue();\n\n const path = /^\\.\\.?\\/?/.test(modulePath)\n ? opts?.relpathResolver\n ? opts.relpathResolver(modulePath)\n : modulePath\n : modulePath;\n\n const typeOnlyDeclaration = declaration.isTypeOnly();\n\n const defaultImport = typeOnlyDeclaration\n ? declaration.getDefaultImport()\n : undefined;\n\n if (defaultImport) {\n const name = defaultImport.getText();\n const text = `import type ${name} from \"${path}\";`;\n declarations.push({\n importDeclaration: {\n name,\n path,\n },\n text,\n });\n if (referencedFiles) {\n referencedFiles.push(...getReferencedFiles(defaultImport));\n }\n }\n\n for (const namedImport of declaration.getNamedImports()) {\n if (namedImport.isTypeOnly() || typeOnlyDeclaration) {\n const nameNode = namedImport.getNameNode();\n const name = nameNode.getText();\n const alias = namedImport.getAliasNode()?.getText();\n const nameText = alias ? `${name} as ${alias}` : name;\n\n declarations.push({\n importDeclaration: {\n name,\n alias,\n path,\n },\n text: `import type { ${nameText} } from \"${path}\";`,\n });\n\n if (referencedFiles) {\n if (nameNode.isKind(SyntaxKind.Identifier)) {\n referencedFiles.push(...getReferencedFiles(nameNode));\n }\n }\n }\n }\n }\n\n for (const declaration of sourceFile.getTypeAliases()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n typeAliasDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getInterfaces()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n interfaceDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getEnums()) {\n const name = declaration.getName();\n const text = declaration.getFullText().trim();\n declarations.push({\n enumDeclaration: { name },\n text,\n });\n }\n\n for (const declaration of sourceFile.getExportDeclarations()) {\n const typeOnlyDeclaration = declaration.isTypeOnly();\n\n const modulePath = declaration.getModuleSpecifierValue();\n\n const path = modulePath\n ? /^\\.\\.?\\/?/.test(modulePath)\n ? opts?.relpathResolver\n ? opts.relpathResolver(modulePath)\n : modulePath\n : modulePath\n : undefined;\n\n for (const namedExport of declaration.getNamedExports()) {\n if (namedExport.isTypeOnly() || typeOnlyDeclaration) {\n const nameNode = namedExport.getNameNode();\n const name = nameNode.getText();\n const alias = namedExport.getAliasNode()?.getText();\n const nameText = alias ? `${name} as ${alias}` : name;\n\n declarations.push({\n exportDeclaration: {\n name,\n alias: alias ?? name,\n path,\n },\n text: path\n ? `export type { ${nameText} } from \"${path}\";`\n : `export type { ${nameText} };`,\n });\n\n if (referencedFiles) {\n if (nameNode.isKind(SyntaxKind.Identifier)) {\n referencedFiles.push(...getReferencedFiles(nameNode));\n }\n }\n }\n }\n }\n\n return referencedFiles\n ? [declarations, [...new Set<string>(referencedFiles)]]\n : [declarations];\n};\n\nconst getReferencedFiles = (importIdentifier: Identifier): Array<string> => {\n // ambient modules may have declarations in multiple files\n const declarations =\n importIdentifier //\n ?.getSymbol()\n ?.getAliasedSymbol()\n ?.getDeclarations() || [];\n\n return declarations.flatMap((e) => {\n const sourceFile = e.getSourceFile();\n return sourceFile //\n ? [sourceFile.getFilePath()]\n : [];\n });\n};\n\nconst extractGenerics = (\n callExpression: CallExpression,\n): Array<{ node: Node; comments: Array<string> }> => {\n return callExpression.getTypeArguments().map((node) => {\n return {\n node,\n comments: node\n .getLeadingCommentRanges()\n .map((range) => range.getText().trim()),\n };\n });\n};\n\nexport const typeResolverFactory = ({ appRoot }: PluginOptionsResolved) => {\n const project = createProject({\n tsConfigFilePath: resolve(appRoot, \"tsconfig.json\"),\n skipAddingFilesFromTsConfig: true,\n });\n\n const literalTypesResolver = (\n literalTypes: string,\n options: Parameters<typeof flattener>[2],\n ) => {\n const sourceFile = project.createSourceFile(\n `${crc(literalTypes)}-${Date.now()}.ts`,\n literalTypes,\n { overwrite: true },\n );\n\n const resolvedTypes = flattener(project, sourceFile, {\n ...options,\n stripComments: true,\n });\n\n project.removeSourceFile(sourceFile);\n\n return resolvedTypes;\n };\n\n return {\n getSourceFile: (fileFullpath: string) => {\n return (\n project.getSourceFile(fileFullpath) ||\n project.addSourceFileAtPath(fileFullpath)\n );\n },\n refreshSourceFile: async (fileFullpath: string) => {\n const sourceFile = project.getSourceFile(fileFullpath);\n if (sourceFile) {\n await sourceFile.refreshFromFileSystem();\n }\n },\n literalTypesResolver,\n };\n};\n", "import { mkdir, readFile, writeFile } from \"node:fs/promises\";\nimport { dirname, resolve } from \"node:path\";\n\nimport crc from \"crc/crc32\";\n\n/**\n * Import from published package to ensure correct version at runtime.\n * Local import would be bundled with pre-bump version; this external\n * import resolves to the actual published package.json.\n * */\nimport self from \"@kosmojs/dev/package.json\" with { type: \"json\" };\nimport { type ApiRoute, pathExists, pathResolver } from \"@kosmojs/devlib\";\n\nexport type Cache = {\n hash: number;\n referencedFiles: Record<string, number>;\n} & Pick<\n ApiRoute,\n | \"params\"\n | \"methods\"\n | \"typeDeclarations\"\n | \"numericParams\"\n | \"payloadTypes\"\n | \"responseTypes\"\n>;\n\ntype ExtraContext = Record<string | number, unknown>;\n\nexport const cacheFactory = (\n route: Pick<ApiRoute, \"file\" | \"fileFullpath\" | \"importName\">,\n {\n appRoot,\n sourceFolder,\n extraContext,\n }: {\n appRoot: string;\n sourceFolder: string;\n extraContext?: ExtraContext;\n },\n) => {\n const cacheFile = pathResolver({\n appRoot,\n sourceFolder,\n }).resolve(\"apiLibDir\", dirname(route.file), \"cache.json\");\n\n const getCache = async (opt?: {\n validate?: boolean;\n }): Promise<Cache | undefined> => {\n if (await pathExists(cacheFile)) {\n try {\n const cache = JSON.parse(await readFile(cacheFile, \"utf8\"));\n return opt?.validate //\n ? validateCache(cache)\n : cache;\n } catch (_e) {}\n }\n return undefined;\n };\n\n const persistCache = async ({\n referencedFiles: _referencedFiles,\n ...rest\n }: Omit<Cache, \"hash\" | \"referencedFiles\"> & {\n referencedFiles: Array<string>;\n }): Promise<Cache> => {\n const hash = await generateFileHash(route.fileFullpath, {\n ...extraContext,\n });\n\n const referencedFiles: Cache[\"referencedFiles\"] = {};\n\n for (const file of _referencedFiles) {\n referencedFiles[\n // Strip project root to ensure cached paths are relative\n // and portable across environments (CI, local, etc.)\n file.replace(`${appRoot}/`, \"\")\n ] = await generateFileHash(file);\n }\n\n const cache = { ...rest, hash, referencedFiles };\n\n await mkdir(dirname(cacheFile), { recursive: true });\n await writeFile(cacheFile, JSON.stringify(cache, null, 2), \"utf8\");\n\n return cache;\n };\n\n const validateCache = async (\n cache: Cache | undefined,\n ): Promise<Cache | undefined> => {\n if (!cache?.hash) {\n return;\n }\n\n if (!cache.typeDeclarations || !cache.referencedFiles) {\n // incomplete cache\n return;\n }\n\n const hash = await generateFileHash(route.fileFullpath, {\n ...extraContext,\n });\n\n if (!identicalHashSum(cache.hash, hash)) {\n // route itself updated\n return;\n }\n\n for (const [file, hash] of Object.entries(cache.referencedFiles)) {\n if (\n !identicalHashSum(hash, await generateFileHash(resolve(appRoot, file)))\n ) {\n // some referenced file updated\n return;\n }\n }\n\n return cache;\n };\n\n return {\n getCache,\n validateCache,\n persistCache,\n };\n};\n\nconst generateFileHash = async (\n file: string,\n extraContext?: ExtraContext,\n): Promise<number> => {\n let fileContent: string | undefined;\n try {\n fileContent = await readFile(file, \"utf8\");\n } catch (_e) {\n // file could be deleted since last build\n return 0;\n }\n return fileContent\n ? crc(\n JSON.stringify({\n ...extraContext,\n [self.cacheVersion]: fileContent,\n }),\n )\n : 0;\n};\n\n// return true if sums are identical\nconst identicalHashSum = (a: number, b: number) => {\n return a === b;\n};\n", "{{#each resolvedTypes}}\nexport type {{name}} = {{text}};\n{{/each}}\n", "{{#each typeDeclarations}}{{text}}\n{{/each}}\n\nexport type {{params.id}} = {\n {{#each paramsSchema}}\n \"{{name}}\"{{#unless isRequired}}?{{/unless}}:{{#if isRest}} Array<{{/if}}\n {{#if refinement}}{{refinement.text}}{{else}}string{{/if}}\n {{#if isRest}}>{{/if}}\n {{/each}}\n};\n\n{{#each payloadTypes}}\nexport type {{id}} = {{text}};\n{{/each}}\n\n{{#each responseTypes}}\nexport type {{id}} = {{text}};\n{{/each}}\n", "import { basename } from \"node:path\";\n\nimport {\n type NestedRouteEntry,\n type RouteEntry,\n sortRoutes,\n} from \"@kosmojs/devlib\";\n\nimport { PAGE_INDEX_BASENAME, PAGE_LAYOUT_BASENAME } from \"./resolve\";\n\n/**\n * Build a nested route tree from flat route entries.\n * */\nexport const nestedRoutesFactory = (routeEntries: Array<RouteEntry>) => {\n const entryStack = structuredClone(routeEntries).sort(sortRoutes);\n\n /**\n * Group entries by name (at the same level, both layout and index share same name).\n *\n * Handle 3 cases:\n * - both index and layout exists\n * - only index exists\n * - only layout exists\n *\n * */\n const transformEntries = (\n entries: Array<RouteEntry>,\n parent?: RouteEntry,\n ): Array<NestedRouteEntry> => {\n return [...new Set(entries.map((e) => e.name))].flatMap((name) => {\n const nameEntries = entryStack.flatMap(({ fileFullpath, ...entry }) => {\n return entry.name === name ? [entry] : [];\n });\n\n const index = nameEntries.find((e) =>\n basename(e.file).startsWith(PAGE_INDEX_BASENAME),\n ) as RouteEntry;\n\n const layout = nameEntries.find((e) =>\n basename(e.file).startsWith(PAGE_LAYOUT_BASENAME),\n ) as RouteEntry;\n\n if (index || layout) {\n return [\n {\n index: index\n ? {\n ...index,\n pathTokens: index.pathTokens.slice(\n parent?.pathTokens.length || 0,\n ),\n }\n : undefined,\n layout: layout\n ? {\n ...layout,\n pathTokens: layout.pathTokens.slice(\n parent?.pathTokens.length || 0,\n ),\n }\n : undefined,\n parent: parent?.name,\n children: transformEntries(\n findDescendantEntries(index || layout),\n index || layout,\n ),\n },\n ];\n }\n\n return [];\n });\n };\n\n /**\n * Recursively finds direct descendant routes.\n *\n * \"Direct\" means the next existing route in the path hierarchy,\n * skipping intermediate path segments that don't have index/layout files.\n *\n * Example: blog/post/[slug]/index.tsx is a direct child of blog/index.tsx\n * even though \"post\" segment exists (it has no index.tsx).\n * */\n const findDescendantEntries = ({\n name,\n pathTokens,\n }: RouteEntry): Array<RouteEntry> => {\n // Find all potential children - BOTH indexes AND layouts\n const potentialChildren = entryStack.filter((entry) => {\n // Must be deeper than current entry\n if (entry.pathTokens.length <= pathTokens.length) {\n return false;\n }\n // Must be a descendant path\n if (!entry.name.startsWith(`${name}/`)) {\n return false;\n }\n return true;\n });\n\n // Filter to direct children (no intermediate route between parent and child)\n return potentialChildren.filter((child) => {\n // Check if any route exists between parent and child\n const hasIntermediateRoute = potentialChildren.some((intermediate) => {\n if (intermediate === child) {\n return false;\n }\n // Intermediate must be between parent and child in depth\n if (intermediate.pathTokens.length <= pathTokens.length) {\n return false;\n }\n if (intermediate.pathTokens.length >= child.pathTokens.length) {\n return false;\n }\n // Child must be descendant of intermediate\n return child.name.startsWith(`${intermediate.name}/`);\n });\n\n return !hasIntermediateRoute;\n });\n };\n\n // Find root entries - entries that have no parent route\n const rootEntries = entryStack.filter((entry) => {\n // Check if any other entry could be its parent\n const hasParent = entryStack.some((potential) => {\n if (potential === entry) {\n return false;\n }\n if (potential.pathTokens.length >= entry.pathTokens.length) {\n return false;\n }\n return entry.name.startsWith(`${potential.name}/`);\n });\n\n return !hasParent;\n });\n\n return transformEntries(rootEntries);\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["crc", "pathResolver", "defaults", "dirname", "resolve", "crc", "pathResolver", "callExpression", "appRoot", "resolve", "crc", "appRoot", "sourceFolder", "hash", "appRoot", "sourceFolder", "resolve", "appRoot", "sourceFolder", "dirname", "crc", "entry", "generators", "formatters", "pathResolver", "resolve", "appRoot", "sourceFolder", "resolversFactory", "routeFiles", "resolvers", "defaults", "resolve", "pathResolver", "crc"]
7
7
  }
package/pkg/cli/cli.js CHANGED
@@ -11,14 +11,7 @@ import { glob } from "tinyglobby";
11
11
  import { access, constants, cp } from "node:fs/promises";
12
12
  import { basename } from "node:path";
13
13
  import { styleText } from "node:util";
14
- var FRAMEWORK_OPTIONS = [
15
- "none",
16
- "solid",
17
- "react",
18
- "vue"
19
- // TODO: implement svelte generator
20
- // "svelte",
21
- ];
14
+ var FRAMEWORK_OPTIONS = ["none", "solid", "react", "vue"];
22
15
  var DEFAULT_BASE = "/";
23
16
  var DEFAULT_PORT = "4000";
24
17
  var DEFAULT_FRAMEWORK = "none";
@@ -283,6 +276,9 @@ var createSourceFolder = async (projectRoot, folder, opt) => {
283
276
  importName: "ssrGenerator",
284
277
  options: ""
285
278
  });
279
+ Object.assign(dependencies, {
280
+ "path-to-regexp": self.devDependencies["path-to-regexp"]
281
+ });
286
282
  Object.assign(devDependencies, {
287
283
  "@kosmojs/ssr-generator": SEMVER
288
284
  });
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/cli/cli.ts", "../../src/cli/base.ts", "../../src/cli/factory.ts", "../../src/cli/templates/@src/api/app.hbs", "../../src/cli/templates/@src/api/router.hbs", "../../src/cli/templates/@src/api/server.hbs", "../../src/cli/templates/@src/api/use.hbs", "../../src/cli/templates/@src/config/index.hbs", "../../src/cli/templates/@src/vite.config.hbs"],
4
- "sourcesContent": ["#!/usr/bin/env -S node --enable-source-maps --no-warnings=ExperimentalWarning\n\nimport { dirname, resolve } from \"node:path\";\nimport { parseArgs, styleText } from \"node:util\";\n\nimport concurrently from \"concurrently\";\nimport prompts, { type PromptObject } from \"prompts\";\nimport { glob } from \"tinyglobby\";\n\nimport {\n assertNoError,\n DEFAULT_BASE,\n DEFAULT_PORT,\n FRAMEWORK_OPTIONS,\n messageFactory,\n pathExists,\n type SourceFolder,\n validateBase,\n validateName,\n validatePort,\n} from \"./base\";\nimport { createSourceFolder } from \"./factory\";\n\nconst usage = [\n \"\",\n `\uD83D\uDE80 ${styleText([\"bold\", \"underline\", \"cyan\"], \"KosmoJS CLI\")}`,\n \"\",\n\n styleText(\"bold\", \"FOLDER COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo folder\")}`,\n ` Create a new Source Folder in interactive mode, prompting for each step`,\n \"\",\n styleText(\n \"bold\",\n \" Use these options to create a Source Folder in non-interactive mode:\",\n ),\n \"\",\n ` ${styleText(\"cyan\", \"--name\")} ${styleText(\"dim\", \"<name>\")}`,\n ` Source folder name`,\n \"\",\n ` ${styleText(\"cyan\", \"--base\")} ${styleText(\"dim\", \"<path>\")}`,\n ` Base URL`,\n \"\",\n ` ${styleText(\"cyan\", \"--port\")} ${styleText(\"dim\", \"<number>\")}`,\n ` Development server port`,\n \"\",\n ` ${styleText(\"cyan\", \"--framework\")} ${styleText(\"dim\", \"<framework>\")}`,\n ` Frontend framework: ${FRAMEWORK_OPTIONS.map((e) => styleText(\"yellow\", e)).join(\", \")}`,\n \"\",\n ` ${styleText(\"cyan\", \"--ssr\")}`,\n ` Enable server-side rendering (SSR)`,\n \"\",\n\n styleText(\"bold\", \"DEV COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")}`,\n ` Start dev server for all source folders`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")} ${styleText(\"magenta\", \"@admin\")}`,\n ` Start dev server for single source folder`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")} ${styleText(\"magenta\", \"@admin @front\")}`,\n ` Start dev server for multiple source folders`,\n \"\",\n\n styleText(\"bold\", \"BUILD COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")}`,\n ` Build all source folders`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")} ${styleText(\"magenta\", \"@admin\")}`,\n ` Build single source folder`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")} ${styleText(\"magenta\", \"@admin @front\")}`,\n ` Build multiple source folders`,\n \"\",\n\n styleText(\"bold\", \"COMMON OPTIONS\"),\n \"\",\n ` ${styleText(\"magenta\", \"-q, --quiet\")}`,\n ` Suppress all output in non-interactive mode (errors still shown)`,\n \"\",\n ` ${styleText(\"magenta\", \"-h, --help\")}`,\n ` Display this help message and exit`,\n \"\",\n];\n\nconst printUsage = () => {\n for (const line of usage) {\n console.log(line);\n }\n};\n\nconst options = parseArgs({\n options: {\n name: { type: \"string\" },\n framework: { type: \"string\" },\n ssr: { type: \"boolean\" },\n base: { type: \"string\" },\n port: { type: \"string\" },\n quiet: { type: \"boolean\", short: \"q\" },\n help: { type: \"boolean\", short: \"h\" },\n },\n allowPositionals: true,\n strict: true,\n});\n\nif (options.values.help) {\n printUsage();\n process.exit(0);\n}\n\nconst cwd = process.cwd();\n\nconst prefixColors = [\"cyan\", \"magenta\", \"yellow\", \"green\", \"blue\", \"auto\"];\n\nconst packageFile = resolve(cwd, \"package.json\");\nconst packageFileExists = await pathExists(packageFile);\n\nconst packageJson = packageFileExists\n ? await import(packageFile, { with: { type: \"json\" } }).then((e) => e.default)\n : undefined;\n\nconst handlers: Record<\n \"folder\" | \"dev\" | \"build\",\n (f: Array<string>) => Promise<void>\n> = {\n async folder() {\n const messages = messageFactory(\n options.values.quiet ? () => {} : console.log,\n );\n\n if (\"name\" in options.values) {\n // non-interactive mode\n\n assertNoError(() => validateName(options.values.name));\n\n assertNoError(() => validateBase(options.values.base));\n\n assertNoError(() => validatePort(options.values.port));\n\n assertNoError(() => {\n return FRAMEWORK_OPTIONS.includes(options.values.framework as never)\n ? undefined\n : `Invalid framework, use one of: ${FRAMEWORK_OPTIONS.join(\", \")}`;\n });\n\n const folder = options.values as SourceFolder;\n\n await createSourceFolder(cwd, folder);\n\n messages.sourceFolderCreated(folder);\n\n return;\n }\n\n // interactive mode\n\n const onState: PromptObject[\"onState\"] = (state) => {\n if (state.aborted) {\n process.nextTick(() => process.exit(1));\n }\n };\n\n console.log(\n styleText(\n [\"bold\", \"green\"],\n \"\u279C Great! Let's create a new Source Folder:\\n\",\n ),\n );\n\n const folder = await prompts<\n \"name\" | \"base\" | \"port\" | \"framework\" | \"ssr\"\n >([\n {\n type: \"text\",\n name: \"name\",\n message: \"Folder Name\",\n onState,\n validate: (name) => validateName(name) || true,\n },\n\n {\n type: \"text\",\n name: \"base\",\n message: \"Base URL\",\n initial: DEFAULT_BASE,\n onState,\n validate: (base) => validateBase(base || DEFAULT_BASE) || true,\n },\n\n {\n type: \"number\",\n name: \"port\",\n message: \"Dev Server Port\",\n initial: DEFAULT_PORT,\n onState,\n validate: (port) => validatePort(port || DEFAULT_PORT) || true,\n },\n\n {\n type: \"select\",\n name: \"framework\",\n message: \"Frontend Framework\",\n onState,\n choices: FRAMEWORK_OPTIONS.map((name) => {\n return { title: name, value: name };\n }),\n },\n\n {\n type: (prev: (typeof FRAMEWORK_OPTIONS)[number]) => {\n return prev === \"none\" // skip if no framework\n ? undefined\n : \"toggle\";\n },\n name: \"ssr\",\n message: \"Enable server-side rendering (SSR)?\",\n initial: false,\n active: \"yes\",\n inactive: \"no\",\n },\n ]);\n\n await createSourceFolder(cwd, folder);\n\n messages.sourceFolderCreated(folder);\n },\n\n async dev(folders) {\n const { result, commands } = concurrently(\n folders.map((name) => {\n return { name, command: \"vite dev\", cwd: name };\n }),\n {\n prefixColors,\n handleInput: true,\n },\n );\n\n let manualShutdown = false;\n\n process.stdin.on(\"end\", async () => {\n manualShutdown = true;\n console.log(\"\\nEOF detected - stopping all processes...\");\n for (const cmd of commands) {\n cmd.kill();\n }\n // Give processes time to cleanup\n await new Promise((resolve) => setTimeout(resolve, 500));\n });\n\n return result.then(\n () => process.exit(0),\n () => process.exit(manualShutdown ? 0 : 1),\n );\n },\n\n async build(folders) {\n const { result } = concurrently(\n folders.map((name) => {\n return { name, command: \"vite build\", cwd: name };\n }),\n { prefixColors },\n );\n await result;\n },\n};\n\nconst [command, ...optedFolders] = options.positionals as [\n command: keyof typeof handlers,\n ...optedFolders: Array<string>,\n];\n\ntry {\n assertNoError(() => {\n return packageJson?.distDir\n ? undefined\n : \"No KosmoJS project found in current directory\";\n });\n\n assertNoError(() => {\n return handlers[command]\n ? undefined\n : `Invalid command, use one of ${Object.keys(handlers).join(\", \")}`;\n });\n\n if (command === \"folder\") {\n await handlers[command]([]);\n } else {\n const configs = await glob(\n optedFolders.length\n ? optedFolders.map((e) => `${e}/vite.config.*`)\n : \"**/vite.config.*\",\n {\n absolute: false,\n deep: 2,\n },\n );\n\n const sourceFolders = configs.map(dirname);\n\n assertNoError(() => {\n if (optedFolders.length) {\n return optedFolders.length === sourceFolders.length\n ? undefined\n : \"Some of given names does not contain a valid KosmoJS source folder\";\n }\n\n return sourceFolders.length //\n ? undefined\n : \"No source folders detected\";\n });\n\n await handlers[command](sourceFolders);\n }\n} catch (\n // biome-ignore lint: any\n error: any\n) {\n console.error(error.message);\n process.exit(1);\n}\n", "import { access, constants, cp } from \"node:fs/promises\";\nimport { basename } from \"node:path\";\nimport { styleText } from \"node:util\";\n\nexport type Project = { name: string; distDir?: string };\n\nexport type SourceFolder = {\n name: string;\n framework?: (typeof FRAMEWORK_OPTIONS)[number];\n ssr?: boolean;\n base?: string;\n port?: number | string;\n};\n\nexport const CREATE_OPTIONS = [\"project\", \"folder\"] as const;\n\nexport const FRAMEWORK_OPTIONS = [\n \"none\",\n \"solid\",\n \"react\",\n \"vue\",\n // TODO: implement svelte generator\n // \"svelte\",\n] as const;\n\nexport const NODE_VERSION = \"22\";\nexport const DEFAULT_DIST = \"dist\";\nexport const DEFAULT_BASE = \"/\";\nexport const DEFAULT_PORT = \"4000\";\nexport const DEFAULT_FRAMEWORK = \"none\" as const;\n\nexport const copyFiles = async (\n src: string,\n dst: string,\n { exclude = [] }: { exclude?: Array<string | RegExp> } = {},\n): Promise<void> => {\n const filter = exclude.length\n ? (path: string) => {\n return !exclude.some((e) => {\n return typeof e === \"string\" ? e === basename(path) : e.test(path);\n });\n }\n : undefined;\n\n await cp(src, dst, {\n recursive: true,\n force: true,\n filter,\n });\n};\n\nexport const pathExists = async (path: string): Promise<boolean> => {\n try {\n await access(path, constants.F_OK);\n return true;\n } catch {\n return false;\n }\n};\n\nexport const validateName = (name: string | undefined) => {\n if (!name) {\n return \"Invalid name provided\";\n }\n if (/[^\\w.@$+-]/.test(name)) {\n return \"May contain only alphanumerics, hyphens, periods or any of @ $ +\";\n }\n return undefined;\n};\n\nexport const validateBase = (base: string | undefined) => {\n if (!base?.startsWith(\"/\")) {\n return \"Should start with a slash\";\n }\n if (\n [\n // path traversal patterns\n /\\.\\.\\//,\n /\\/\\.\\//,\n ].some((e) => e.test(base.trim()))\n ) {\n return \"Should not contain path traversal patterns\";\n }\n return undefined;\n};\n\nexport const validatePort = (port: string | number | undefined) => {\n if (!port || /[^\\d]/.test(String(port).trim())) {\n return \"Invalid port number\";\n }\n return undefined;\n};\n\nexport const assertNoError = (validator: () => string | undefined) => {\n const error = validator();\n if (error) {\n throw new Error(`${styleText(\"red\", \"\u2717 ERROR\")}: ${error}`);\n }\n};\n\nexport const messageFactory = (logger?: (...lines: Array<unknown>) => void) => {\n const projectCreatedGreets = [\n \"\u2728 Well Done! Your new KosmoJS app is ready\",\n \"\uD83D\uDCAB Excellent! Your new KosmoJS project is all set\",\n \"\uD83C\uDF1F Nice work! Your KosmoJS setup is ready to perform\",\n \"\uD83D\uDE80 Success! Your KosmoJS project is ready for exploration\",\n \"\u2705 All Set! Your KosmoJS project is configured and ready\",\n ];\n\n const sourceFolderCreatedGreets = [\n \"\uD83D\uDCAB Awesome! You just created a new Source Folder\",\n \"\u2728 Nice! Your new Source Folder is ready to use\",\n \"\uD83C\uDFAF Perfect! Source Folder created successfully\",\n \"\u2705 Great! Your Source Folder is all set up\",\n \"\uD83C\uDF1F Excellent! New Source Folder is ready to perform\",\n ];\n\n const messageHandler = (lines: Array<unknown>) => {\n if (!logger) {\n return lines;\n }\n\n for (const line of lines) {\n logger(` ${line}`);\n }\n\n return undefined;\n };\n\n const greetText = (greets: Array<string>) =>\n styleText(\n [\"bold\", \"green\"],\n greets[Math.floor(Math.random() * greets.length)],\n );\n\n const nextStepText = (text: string) => {\n return styleText([\"bold\", \"italic\", \"cyan\"], text);\n };\n\n const cmdText = (cmd: string, ...altCmds: Array<string>) => {\n const altText = altCmds.length\n ? styleText(\"dim\", ` # or ${altCmds.map((e) => `\\`${e}\\``).join(\" / \")}`)\n : \"\";\n return `$ ${styleText(\"blue\", cmd)}${altText}`;\n };\n\n const docsText = () => \"\uD83D\uDCD8 Docs: https://kosmojs.dev\";\n\n return {\n projectCreated(project: Project) {\n return messageHandler([\n \"\",\n greetText(projectCreatedGreets),\n \"\",\n\n `${styleText([\"bold\", \"yellow\"], \"\u279C Next Steps\")}`,\n \"\",\n\n nextStepText(\"\uD83D\uDCE6 Install Dependencies\"),\n cmdText(`cd ./${project.name}`),\n cmdText(\"pnpm install\", \"npm install\", \"yarn install\"),\n \"\",\n\n nextStepText(\"\uD83D\uDCC1 Add a Source Folder\"),\n cmdText(\"pnpm +folder\", \"npm run +folder\", \"yarn +folder\"),\n \"\",\n\n docsText(),\n \"\",\n ]);\n },\n\n sourceFolderCreated(_folder: SourceFolder) {\n return messageHandler([\n \"\",\n greetText(sourceFolderCreatedGreets),\n \"\",\n\n nextStepText(\n \"\uD83D\uDCE6 Now install any new dependencies that may have been added\",\n ),\n cmdText(\"pnpm install\", \"npm install\", \"yarn install\"),\n \"\",\n\n nextStepText(\n \"\uD83D\uDE80 Once dependencies are installed, start the dev server\",\n ),\n cmdText(\"pnpm dev\", \"npm run dev\", \"yarn dev\"),\n \"\",\n\n docsText(),\n \"\",\n ]);\n },\n };\n};\n", "import { writeFile } from \"node:fs/promises\";\nimport { resolve } from \"node:path\";\n\n/**\n * Import from published package to ensure correct version at runtime.\n * Local import would be bundled with pre-bump version; this external\n * import resolves to the actual published package.json.\n * INFO: For best compatibility, all packages should share the same version.\n * When bumping the version (even a patch) for a single package, bump it for all packages\n * to keep versions fully synchronized across the project.\n * */\nimport self from \"@kosmojs/dev/package.json\" with { type: \"json\" };\nimport { defaults, renderToFile } from \"@kosmojs/devlib\";\n\nimport {\n copyFiles,\n DEFAULT_BASE,\n DEFAULT_DIST,\n DEFAULT_FRAMEWORK,\n DEFAULT_PORT,\n NODE_VERSION,\n type Project,\n pathExists,\n type SourceFolder,\n} from \"./base\";\n\nimport srcApiAppTpl from \"./templates/@src/api/app.hbs\";\nimport srcApiRouterTpl from \"./templates/@src/api/router.hbs\";\nimport srcApiServerTpl from \"./templates/@src/api/server.hbs\";\nimport srcApiUseTpl from \"./templates/@src/api/use.hbs\";\nimport srcConfigTpl from \"./templates/@src/config/index.hbs\";\nimport srcViteConfigTpl from \"./templates/@src/vite.config.hbs\";\nimport viteBaseTpl from \"./templates/vite.base.hbs\";\n\nconst TPL_DIR = resolve(import.meta.dirname, \"templates\");\n\ntype Plugin = {\n importDeclaration: string;\n importName: string;\n options: string;\n};\n\ntype Generator = {\n importDeclaration: string;\n importName: string;\n options: string;\n};\n\nconst tsconfigJson = {\n extends: \"@kosmojs/config/tsconfig.vite.json\",\n compilerOptions: {\n paths: {\n [`${defaults.appPrefix}/*`]: [\"./*\", `./${defaults.libDir}/*`],\n },\n },\n};\n\nconst SEMVER = `^${self.version}`;\n\nexport const createProject = async (\n path: string,\n project: Project,\n assets?: {\n NODE_VERSION?: `${number}`;\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n },\n) => {\n const packageJson = {\n type: \"module\",\n distDir: project.distDir || DEFAULT_DIST,\n scripts: {\n dev: \"kosmo dev\",\n build: \"kosmo build\",\n \"+folder\": \"kosmo folder\",\n },\n dependencies: {\n \"@kosmojs/api\": SEMVER,\n qs: self.devDependencies.qs,\n ...assets?.dependencies,\n },\n devDependencies: {\n \"@kosmojs/config\": SEMVER,\n \"@kosmojs/dev\": SEMVER,\n \"@types/node\": self.devDependencies[\"@types/node\"],\n \"@types/qs\": self.devDependencies[\"@types/qs\"],\n esbuild: self.dependencies.esbuild,\n tslib: self.devDependencies.tslib,\n typescript: self.dependencies.typescript,\n vite: self.devDependencies.vite,\n ...assets?.devDependencies,\n },\n pnpm: {\n onlyBuiltDependencies: [\"esbuild\"],\n },\n };\n\n const esbuildJson = {\n bundle: true,\n platform: \"node\",\n target: `node${assets?.NODE_VERSION || NODE_VERSION}`,\n format: \"esm\",\n packages: \"external\",\n sourcemap: \"linked\",\n logLevel: \"info\",\n };\n\n const projectPath = resolve(path, project.name);\n\n if (await pathExists(projectPath)) {\n throw new Error(`${project.name} already exists`);\n }\n\n await copyFiles(TPL_DIR, projectPath, {\n exclude: [/@src/, /.+\\.hbs/],\n });\n\n for (const [file, template] of [\n [\"vite.base.ts\", viteBaseTpl],\n [\"esbuild.json\", JSON.stringify(esbuildJson, null, 2)],\n [\"package.json\", JSON.stringify(packageJson, null, 2)],\n [\"tsconfig.json\", JSON.stringify(tsconfigJson, null, 2)],\n ]) {\n await renderToFile(resolve(projectPath, file), template, {\n defaults,\n distDir: project.distDir || DEFAULT_DIST,\n });\n }\n};\n\nexport const createSourceFolder = async (\n projectRoot: string, // path inside project\n folder: SourceFolder,\n opt?: {\n frameworkOptions?: Record<string, unknown>;\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n },\n) => {\n const folderPath = resolve(projectRoot, folder.name);\n\n if (await pathExists(folderPath)) {\n throw new Error(`${folder.name} already exists`);\n }\n\n await copyFiles(resolve(TPL_DIR, \"@src\"), folderPath, {\n exclude: [/.+\\.hbs/],\n });\n\n const packageFile = resolve(projectRoot, \"package.json\");\n\n const packageImport = await import(packageFile, {\n with: { type: \"json\" },\n }).then((e) => e.default);\n\n const tsconfigFile = resolve(projectRoot, \"tsconfig.json\");\n\n const tsconfigImport = await import(tsconfigFile, {\n with: { type: \"json\" },\n }).then((e) => e.default);\n\n const compilerOptions = {\n ...tsconfigImport?.compilerOptions,\n // instruct TypeScript to preserve JSX\n jsx: \"preserve\",\n };\n\n const plugins: Array<Plugin> = [];\n const generators: Array<Generator> = [];\n\n const dependencies: Record<string, string> = {};\n const devDependencies: Record<string, string> = {};\n\n const framework: SourceFolder[\"framework\"] =\n folder.framework || DEFAULT_FRAMEWORK;\n\n if (framework === \"solid\") {\n Object.assign(dependencies, {\n \"@solidjs/router\": self.devDependencies[\"@solidjs/router\"],\n \"solid-js\": self.devDependencies[\"solid-js\"],\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/solid-generator\": SEMVER,\n \"vite-plugin-solid\": self.devDependencies[\"vite-plugin-solid\"],\n });\n\n plugins.push({\n importDeclaration: `import solidPlugin from \"vite-plugin-solid\";`,\n importName: \"solidPlugin\",\n options: folder.ssr ? \"{ ssr: true }\" : \"\",\n });\n\n generators.push({\n importDeclaration: `import solidGenerator from \"@kosmojs/solid-generator\";`,\n importName: \"solidGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n\n compilerOptions.jsxImportSource = \"solid-js\";\n } else if (framework === \"react\") {\n Object.assign(dependencies, {\n react: self.devDependencies.react,\n \"react-router\": self.devDependencies[\"react-router\"],\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/react-generator\": SEMVER,\n \"@vitejs/plugin-react\": self.devDependencies[\"@vitejs/plugin-react\"],\n \"@types/react\": self.devDependencies[\"@types/react\"],\n \"@types/react-dom\": self.devDependencies[\"@types/react-dom\"],\n \"react-dom\": self.devDependencies[\"react-dom\"],\n });\n\n plugins.push({\n importDeclaration: `import reactPlugin from \"@vitejs/plugin-react\";`,\n importName: \"reactPlugin\",\n options: \"\",\n });\n\n generators.push({\n importDeclaration: `import reactGenerator from \"@kosmojs/react-generator\";`,\n importName: \"reactGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n\n compilerOptions.jsxImportSource = \"react\";\n } else if (framework === \"vue\") {\n Object.assign(dependencies, {\n \"vue-router\": self.devDependencies[\"vue-router\"],\n vue: self.devDependencies.vue,\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/vue-generator\": SEMVER,\n \"@vitejs/plugin-vue\": self.devDependencies[\"@vitejs/plugin-vue\"],\n });\n\n plugins.push({\n importDeclaration: `import vuePlugin from \"@vitejs/plugin-vue\";`,\n importName: \"vuePlugin\",\n options: \"\",\n });\n\n generators.push({\n importDeclaration: `import vueGenerator from \"@kosmojs/vue-generator\";`,\n importName: \"vueGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n }\n\n if (folder.ssr) {\n generators.push({\n importDeclaration: `import ssrGenerator from \"@kosmojs/ssr-generator\";`,\n importName: \"ssrGenerator\",\n options: \"\",\n });\n Object.assign(devDependencies, {\n \"@kosmojs/ssr-generator\": SEMVER,\n });\n }\n\n const context = {\n folder: {\n base: DEFAULT_BASE,\n port: DEFAULT_PORT,\n ...folder,\n },\n defaults,\n plugins,\n generators,\n importPathmap: {\n core: [defaults.appPrefix, defaults.coreDir, defaults.apiDir].join(\"/\"),\n lib: [folder.name, defaults.apiLibDir].join(\"/\"),\n },\n };\n\n for (const [file, template] of [\n [`${defaults.configDir}/index.ts`, srcConfigTpl],\n [`${defaults.apiDir}/app.ts`, srcApiAppTpl],\n [`${defaults.apiDir}/router.ts`, srcApiRouterTpl],\n [`${defaults.apiDir}/server.ts`, srcApiServerTpl],\n [`${defaults.apiDir}/use.ts`, srcApiUseTpl],\n [\"vite.config.ts\", srcViteConfigTpl],\n // stub files for initial build to pass;\n // generators will fill them with appropriate content.\n [`${defaults.apiDir}/index/index.ts`, \"\"],\n ...([\"solid\", \"react\"].includes(framework)\n ? [\n [`${defaults.pagesDir}/index/index.tsx`, \"\"],\n [`${defaults.entryDir}/client.tsx`, \"\"],\n ]\n : []),\n ...([\"vue\"].includes(framework)\n ? [\n [`${defaults.pagesDir}/index/index.vue`, \"\"],\n [`${defaults.entryDir}/client.ts`, \"\"],\n ]\n : []),\n ]) {\n await renderToFile(resolve(folderPath, file), template, context);\n }\n\n const tsconfigUpdated = {\n ...tsconfigJson,\n ...tsconfigImport,\n compilerOptions: {\n ...compilerOptions,\n paths: {\n ...compilerOptions?.paths,\n [`${folder.name}/*`]: [\n `./${folder.name}/*`,\n `./${defaults.libDir}/${folder.name}/*`,\n ],\n },\n },\n };\n\n await writeFile(\n tsconfigFile,\n JSON.stringify(tsconfigUpdated, null, 2),\n \"utf8\",\n );\n\n const packageUpdated = {\n ...packageImport,\n dependencies: {\n ...packageImport.dependencies,\n ...dependencies,\n ...opt?.dependencies,\n },\n devDependencies: {\n ...packageImport.devDependencies,\n ...devDependencies,\n ...opt?.devDependencies,\n },\n };\n\n await writeFile(packageFile, JSON.stringify(packageUpdated, null, 2));\n};\n", "import createApp from \"{{importPathmap.core}}/app\";\n\nimport router from \"./router\";\n\nexport default () => {\n const app = createApp();\n\n // routes goes latest\n app.use(router.routes());\n\n return app;\n};\n\n/**\n * In dev mode, determines whether to pass the request to API handler or to Vite.\nexport const devMiddlewareFactory: import(\"@kosmojs/api\").DevMiddlewareFactory = (\n app,\n) => {\n return (req, res, next) => {\n return req.url?.startsWith(\"...\")\n ? app?.callback()(req, res) // send request to api handler\n : next(); // send request to vite dev server\n };\n};\n * */\n\n/**\n * In dev mode, used to cleanup before reloading api handler.\nexport const teardownHandler: import(\"@kosmojs/api\").TeardownHandler = () => {\n // close db connections, server sockets etc.\n};\n * */\n", "import { routerRoutes } from \"{{importPathmap.lib}}\";\n\nimport createRouter from \"{{importPathmap.core}}/router\";\n\nconst router = createRouter();\n\nfor (const { name, path, methods, middleware } of routerRoutes) {\n router.register(path, methods, middleware, { name });\n}\n\nexport default router;\n", "import createServer from \"{{importPathmap.core}}/server\";\nimport createApp from \"./app\";\n\ncreateServer(createApp);\n", "import globalMiddleware from \"{{defaults.appPrefix}}/core/api/use\";\n\nexport default [\n // Global middleware applied to all routes\n ...globalMiddleware,\n];\n", "export const baseurl = \"{{folder.base}}\";\nexport const apiurl = \"/api\"; // relative to baseurl\n", "import { join } from \"node:path\";\n\n{{#each plugins}}{{importDeclaration}}\n{{/each}}\nimport devPlugin, { apiGenerator, fetchGenerator } from \"@kosmojs/dev\";\n{{#each generators}}{{importDeclaration}}\n{{/each}}\n\nimport defineConfig from \"../vite.base\";\nimport { apiurl, baseurl } from \"./config\";\n\nexport default defineConfig(import.meta.dirname, {\n base: join(baseurl, \"/\"),\n server: {\n port: {{folder.port}},\n },\n plugins: [\n {{#each plugins}}{{importName}}({{options}}),\n {{/each}}\n devPlugin(apiurl, {\n generators: [\n apiGenerator(),\n fetchGenerator(),\n {{#each generators}}{{importName}}({{options}}),\n {{/each}}\n ],\n }),\n ],\n});\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["#!/usr/bin/env -S node --enable-source-maps --no-warnings=ExperimentalWarning\n\nimport { dirname, resolve } from \"node:path\";\nimport { parseArgs, styleText } from \"node:util\";\n\nimport concurrently from \"concurrently\";\nimport prompts, { type PromptObject } from \"prompts\";\nimport { glob } from \"tinyglobby\";\n\nimport {\n assertNoError,\n DEFAULT_BASE,\n DEFAULT_PORT,\n FRAMEWORK_OPTIONS,\n messageFactory,\n pathExists,\n type SourceFolder,\n validateBase,\n validateName,\n validatePort,\n} from \"./base\";\nimport { createSourceFolder } from \"./factory\";\n\nconst usage = [\n \"\",\n `\uD83D\uDE80 ${styleText([\"bold\", \"underline\", \"cyan\"], \"KosmoJS CLI\")}`,\n \"\",\n\n styleText(\"bold\", \"FOLDER COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo folder\")}`,\n ` Create a new Source Folder in interactive mode, prompting for each step`,\n \"\",\n styleText(\n \"bold\",\n \" Use these options to create a Source Folder in non-interactive mode:\",\n ),\n \"\",\n ` ${styleText(\"cyan\", \"--name\")} ${styleText(\"dim\", \"<name>\")}`,\n ` Source folder name`,\n \"\",\n ` ${styleText(\"cyan\", \"--base\")} ${styleText(\"dim\", \"<path>\")}`,\n ` Base URL`,\n \"\",\n ` ${styleText(\"cyan\", \"--port\")} ${styleText(\"dim\", \"<number>\")}`,\n ` Development server port`,\n \"\",\n ` ${styleText(\"cyan\", \"--framework\")} ${styleText(\"dim\", \"<framework>\")}`,\n ` Frontend framework: ${FRAMEWORK_OPTIONS.map((e) => styleText(\"yellow\", e)).join(\", \")}`,\n \"\",\n ` ${styleText(\"cyan\", \"--ssr\")}`,\n ` Enable server-side rendering (SSR)`,\n \"\",\n\n styleText(\"bold\", \"DEV COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")}`,\n ` Start dev server for all source folders`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")} ${styleText(\"magenta\", \"@admin\")}`,\n ` Start dev server for single source folder`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo dev\")} ${styleText(\"magenta\", \"@admin @front\")}`,\n ` Start dev server for multiple source folders`,\n \"\",\n\n styleText(\"bold\", \"BUILD COMMAND\"),\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")}`,\n ` Build all source folders`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")} ${styleText(\"magenta\", \"@admin\")}`,\n ` Build single source folder`,\n \"\",\n ` ${styleText(\"blue\", \"kosmo build\")} ${styleText(\"magenta\", \"@admin @front\")}`,\n ` Build multiple source folders`,\n \"\",\n\n styleText(\"bold\", \"COMMON OPTIONS\"),\n \"\",\n ` ${styleText(\"magenta\", \"-q, --quiet\")}`,\n ` Suppress all output in non-interactive mode (errors still shown)`,\n \"\",\n ` ${styleText(\"magenta\", \"-h, --help\")}`,\n ` Display this help message and exit`,\n \"\",\n];\n\nconst printUsage = () => {\n for (const line of usage) {\n console.log(line);\n }\n};\n\nconst options = parseArgs({\n options: {\n name: { type: \"string\" },\n framework: { type: \"string\" },\n ssr: { type: \"boolean\" },\n base: { type: \"string\" },\n port: { type: \"string\" },\n quiet: { type: \"boolean\", short: \"q\" },\n help: { type: \"boolean\", short: \"h\" },\n },\n allowPositionals: true,\n strict: true,\n});\n\nif (options.values.help) {\n printUsage();\n process.exit(0);\n}\n\nconst cwd = process.cwd();\n\nconst prefixColors = [\"cyan\", \"magenta\", \"yellow\", \"green\", \"blue\", \"auto\"];\n\nconst packageFile = resolve(cwd, \"package.json\");\nconst packageFileExists = await pathExists(packageFile);\n\nconst packageJson = packageFileExists\n ? await import(packageFile, { with: { type: \"json\" } }).then((e) => e.default)\n : undefined;\n\nconst handlers: Record<\n \"folder\" | \"dev\" | \"build\",\n (f: Array<string>) => Promise<void>\n> = {\n async folder() {\n const messages = messageFactory(\n options.values.quiet ? () => {} : console.log,\n );\n\n if (\"name\" in options.values) {\n // non-interactive mode\n\n assertNoError(() => validateName(options.values.name));\n\n assertNoError(() => validateBase(options.values.base));\n\n assertNoError(() => validatePort(options.values.port));\n\n assertNoError(() => {\n return FRAMEWORK_OPTIONS.includes(options.values.framework as never)\n ? undefined\n : `Invalid framework, use one of: ${FRAMEWORK_OPTIONS.join(\", \")}`;\n });\n\n const folder = options.values as SourceFolder;\n\n await createSourceFolder(cwd, folder);\n\n messages.sourceFolderCreated(folder);\n\n return;\n }\n\n // interactive mode\n\n const onState: PromptObject[\"onState\"] = (state) => {\n if (state.aborted) {\n process.nextTick(() => process.exit(1));\n }\n };\n\n console.log(\n styleText(\n [\"bold\", \"green\"],\n \"\u279C Great! Let's create a new Source Folder:\\n\",\n ),\n );\n\n const folder = await prompts<\n \"name\" | \"base\" | \"port\" | \"framework\" | \"ssr\"\n >([\n {\n type: \"text\",\n name: \"name\",\n message: \"Folder Name\",\n onState,\n validate: (name) => validateName(name) || true,\n },\n\n {\n type: \"text\",\n name: \"base\",\n message: \"Base URL\",\n initial: DEFAULT_BASE,\n onState,\n validate: (base) => validateBase(base || DEFAULT_BASE) || true,\n },\n\n {\n type: \"number\",\n name: \"port\",\n message: \"Dev Server Port\",\n initial: DEFAULT_PORT,\n onState,\n validate: (port) => validatePort(port || DEFAULT_PORT) || true,\n },\n\n {\n type: \"select\",\n name: \"framework\",\n message: \"Frontend Framework\",\n onState,\n choices: FRAMEWORK_OPTIONS.map((name) => {\n return { title: name, value: name };\n }),\n },\n\n {\n type: (prev: (typeof FRAMEWORK_OPTIONS)[number]) => {\n return prev === \"none\" // skip if no framework\n ? undefined\n : \"toggle\";\n },\n name: \"ssr\",\n message: \"Enable server-side rendering (SSR)?\",\n initial: false,\n active: \"yes\",\n inactive: \"no\",\n },\n ]);\n\n await createSourceFolder(cwd, folder);\n\n messages.sourceFolderCreated(folder);\n },\n\n async dev(folders) {\n const { result, commands } = concurrently(\n folders.map((name) => {\n return { name, command: \"vite dev\", cwd: name };\n }),\n {\n prefixColors,\n handleInput: true,\n },\n );\n\n let manualShutdown = false;\n\n process.stdin.on(\"end\", async () => {\n manualShutdown = true;\n console.log(\"\\nEOF detected - stopping all processes...\");\n for (const cmd of commands) {\n cmd.kill();\n }\n // Give processes time to cleanup\n await new Promise((resolve) => setTimeout(resolve, 500));\n });\n\n return result.then(\n () => process.exit(0),\n () => process.exit(manualShutdown ? 0 : 1),\n );\n },\n\n async build(folders) {\n const { result } = concurrently(\n folders.map((name) => {\n return { name, command: \"vite build\", cwd: name };\n }),\n { prefixColors },\n );\n await result;\n },\n};\n\nconst [command, ...optedFolders] = options.positionals as [\n command: keyof typeof handlers,\n ...optedFolders: Array<string>,\n];\n\ntry {\n assertNoError(() => {\n return packageJson?.distDir\n ? undefined\n : \"No KosmoJS project found in current directory\";\n });\n\n assertNoError(() => {\n return handlers[command]\n ? undefined\n : `Invalid command, use one of ${Object.keys(handlers).join(\", \")}`;\n });\n\n if (command === \"folder\") {\n await handlers[command]([]);\n } else {\n const configs = await glob(\n optedFolders.length\n ? optedFolders.map((e) => `${e}/vite.config.*`)\n : \"**/vite.config.*\",\n {\n absolute: false,\n deep: 2,\n },\n );\n\n const sourceFolders = configs.map(dirname);\n\n assertNoError(() => {\n if (optedFolders.length) {\n return optedFolders.length === sourceFolders.length\n ? undefined\n : \"Some of given names does not contain a valid KosmoJS source folder\";\n }\n\n return sourceFolders.length //\n ? undefined\n : \"No source folders detected\";\n });\n\n await handlers[command](sourceFolders);\n }\n} catch (\n // biome-ignore lint: any\n error: any\n) {\n console.error(error.message);\n process.exit(1);\n}\n", "import { access, constants, cp } from \"node:fs/promises\";\nimport { basename } from \"node:path\";\nimport { styleText } from \"node:util\";\n\nexport type Project = { name: string; distDir?: string };\n\nexport type SourceFolder = {\n name: string;\n framework?: (typeof FRAMEWORK_OPTIONS)[number];\n ssr?: boolean;\n base?: string;\n port?: number | string;\n};\n\nexport const CREATE_OPTIONS = [\"project\", \"folder\"] as const;\n\nexport const FRAMEWORK_OPTIONS = [\"none\", \"solid\", \"react\", \"vue\"] as const;\n\nexport const NODE_VERSION = \"22\";\nexport const DEFAULT_DIST = \"dist\";\nexport const DEFAULT_BASE = \"/\";\nexport const DEFAULT_PORT = \"4000\";\nexport const DEFAULT_FRAMEWORK = \"none\" as const;\n\nexport const copyFiles = async (\n src: string,\n dst: string,\n { exclude = [] }: { exclude?: Array<string | RegExp> } = {},\n): Promise<void> => {\n const filter = exclude.length\n ? (path: string) => {\n return !exclude.some((e) => {\n return typeof e === \"string\" ? e === basename(path) : e.test(path);\n });\n }\n : undefined;\n\n await cp(src, dst, {\n recursive: true,\n force: true,\n filter,\n });\n};\n\nexport const pathExists = async (path: string): Promise<boolean> => {\n try {\n await access(path, constants.F_OK);\n return true;\n } catch {\n return false;\n }\n};\n\nexport const validateName = (name: string | undefined) => {\n if (!name) {\n return \"Invalid name provided\";\n }\n if (/[^\\w.@$+-]/.test(name)) {\n return \"May contain only alphanumerics, hyphens, periods or any of @ $ +\";\n }\n return undefined;\n};\n\nexport const validateBase = (base: string | undefined) => {\n if (!base?.startsWith(\"/\")) {\n return \"Should start with a slash\";\n }\n if (\n [\n // path traversal patterns\n /\\.\\.\\//,\n /\\/\\.\\//,\n ].some((e) => e.test(base.trim()))\n ) {\n return \"Should not contain path traversal patterns\";\n }\n return undefined;\n};\n\nexport const validatePort = (port: string | number | undefined) => {\n if (!port || /[^\\d]/.test(String(port).trim())) {\n return \"Invalid port number\";\n }\n return undefined;\n};\n\nexport const assertNoError = (validator: () => string | undefined) => {\n const error = validator();\n if (error) {\n throw new Error(`${styleText(\"red\", \"\u2717 ERROR\")}: ${error}`);\n }\n};\n\nexport const messageFactory = (logger?: (...lines: Array<unknown>) => void) => {\n const projectCreatedGreets = [\n \"\u2728 Well Done! Your new KosmoJS app is ready\",\n \"\uD83D\uDCAB Excellent! Your new KosmoJS project is all set\",\n \"\uD83C\uDF1F Nice work! Your KosmoJS setup is ready to perform\",\n \"\uD83D\uDE80 Success! Your KosmoJS project is ready for exploration\",\n \"\u2705 All Set! Your KosmoJS project is configured and ready\",\n ];\n\n const sourceFolderCreatedGreets = [\n \"\uD83D\uDCAB Awesome! You just created a new Source Folder\",\n \"\u2728 Nice! Your new Source Folder is ready to use\",\n \"\uD83C\uDFAF Perfect! Source Folder created successfully\",\n \"\u2705 Great! Your Source Folder is all set up\",\n \"\uD83C\uDF1F Excellent! New Source Folder is ready to perform\",\n ];\n\n const messageHandler = (lines: Array<unknown>) => {\n if (!logger) {\n return lines;\n }\n\n for (const line of lines) {\n logger(` ${line}`);\n }\n\n return undefined;\n };\n\n const greetText = (greets: Array<string>) =>\n styleText(\n [\"bold\", \"green\"],\n greets[Math.floor(Math.random() * greets.length)],\n );\n\n const nextStepText = (text: string) => {\n return styleText([\"bold\", \"italic\", \"cyan\"], text);\n };\n\n const cmdText = (cmd: string, ...altCmds: Array<string>) => {\n const altText = altCmds.length\n ? styleText(\"dim\", ` # or ${altCmds.map((e) => `\\`${e}\\``).join(\" / \")}`)\n : \"\";\n return `$ ${styleText(\"blue\", cmd)}${altText}`;\n };\n\n const docsText = () => \"\uD83D\uDCD8 Docs: https://kosmojs.dev\";\n\n return {\n projectCreated(project: Project) {\n return messageHandler([\n \"\",\n greetText(projectCreatedGreets),\n \"\",\n\n `${styleText([\"bold\", \"yellow\"], \"\u279C Next Steps\")}`,\n \"\",\n\n nextStepText(\"\uD83D\uDCE6 Install Dependencies\"),\n cmdText(`cd ./${project.name}`),\n cmdText(\"pnpm install\", \"npm install\", \"yarn install\"),\n \"\",\n\n nextStepText(\"\uD83D\uDCC1 Add a Source Folder\"),\n cmdText(\"pnpm +folder\", \"npm run +folder\", \"yarn +folder\"),\n \"\",\n\n docsText(),\n \"\",\n ]);\n },\n\n sourceFolderCreated(_folder: SourceFolder) {\n return messageHandler([\n \"\",\n greetText(sourceFolderCreatedGreets),\n \"\",\n\n nextStepText(\n \"\uD83D\uDCE6 Now install any new dependencies that may have been added\",\n ),\n cmdText(\"pnpm install\", \"npm install\", \"yarn install\"),\n \"\",\n\n nextStepText(\n \"\uD83D\uDE80 Once dependencies are installed, start the dev server\",\n ),\n cmdText(\"pnpm dev\", \"npm run dev\", \"yarn dev\"),\n \"\",\n\n docsText(),\n \"\",\n ]);\n },\n };\n};\n", "import { writeFile } from \"node:fs/promises\";\nimport { resolve } from \"node:path\";\n\n/**\n * Import from published package to ensure correct version at runtime.\n * Local import would be bundled with pre-bump version; this external\n * import resolves to the actual published package.json.\n * INFO: For best compatibility, all packages should share the same version.\n * When bumping the version (even a patch) for a single package, bump it for all packages\n * to keep versions fully synchronized across the project.\n * */\nimport self from \"@kosmojs/dev/package.json\" with { type: \"json\" };\nimport { defaults, renderToFile } from \"@kosmojs/devlib\";\n\nimport {\n copyFiles,\n DEFAULT_BASE,\n DEFAULT_DIST,\n DEFAULT_FRAMEWORK,\n DEFAULT_PORT,\n NODE_VERSION,\n type Project,\n pathExists,\n type SourceFolder,\n} from \"./base\";\n\nimport srcApiAppTpl from \"./templates/@src/api/app.hbs\";\nimport srcApiRouterTpl from \"./templates/@src/api/router.hbs\";\nimport srcApiServerTpl from \"./templates/@src/api/server.hbs\";\nimport srcApiUseTpl from \"./templates/@src/api/use.hbs\";\nimport srcConfigTpl from \"./templates/@src/config/index.hbs\";\nimport srcViteConfigTpl from \"./templates/@src/vite.config.hbs\";\nimport viteBaseTpl from \"./templates/vite.base.hbs\";\n\nconst TPL_DIR = resolve(import.meta.dirname, \"templates\");\n\ntype Plugin = {\n importDeclaration: string;\n importName: string;\n options: string;\n};\n\ntype Generator = {\n importDeclaration: string;\n importName: string;\n options: string;\n};\n\nconst tsconfigJson = {\n extends: \"@kosmojs/config/tsconfig.vite.json\",\n compilerOptions: {\n paths: {\n [`${defaults.appPrefix}/*`]: [\"./*\", `./${defaults.libDir}/*`],\n },\n },\n};\n\nconst SEMVER = `^${self.version}`;\n\nexport const createProject = async (\n path: string,\n project: Project,\n assets?: {\n NODE_VERSION?: `${number}`;\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n },\n) => {\n const packageJson = {\n type: \"module\",\n distDir: project.distDir || DEFAULT_DIST,\n scripts: {\n dev: \"kosmo dev\",\n build: \"kosmo build\",\n \"+folder\": \"kosmo folder\",\n },\n dependencies: {\n \"@kosmojs/api\": SEMVER,\n qs: self.devDependencies.qs,\n ...assets?.dependencies,\n },\n devDependencies: {\n \"@kosmojs/config\": SEMVER,\n \"@kosmojs/dev\": SEMVER,\n \"@types/node\": self.devDependencies[\"@types/node\"],\n \"@types/qs\": self.devDependencies[\"@types/qs\"],\n esbuild: self.dependencies.esbuild,\n tslib: self.devDependencies.tslib,\n typescript: self.dependencies.typescript,\n vite: self.devDependencies.vite,\n ...assets?.devDependencies,\n },\n pnpm: {\n onlyBuiltDependencies: [\"esbuild\"],\n },\n };\n\n const esbuildJson = {\n bundle: true,\n platform: \"node\",\n target: `node${assets?.NODE_VERSION || NODE_VERSION}`,\n format: \"esm\",\n packages: \"external\",\n sourcemap: \"linked\",\n logLevel: \"info\",\n };\n\n const projectPath = resolve(path, project.name);\n\n if (await pathExists(projectPath)) {\n throw new Error(`${project.name} already exists`);\n }\n\n await copyFiles(TPL_DIR, projectPath, {\n exclude: [/@src/, /.+\\.hbs/],\n });\n\n for (const [file, template] of [\n [\"vite.base.ts\", viteBaseTpl],\n [\"esbuild.json\", JSON.stringify(esbuildJson, null, 2)],\n [\"package.json\", JSON.stringify(packageJson, null, 2)],\n [\"tsconfig.json\", JSON.stringify(tsconfigJson, null, 2)],\n ]) {\n await renderToFile(resolve(projectPath, file), template, {\n defaults,\n distDir: project.distDir || DEFAULT_DIST,\n });\n }\n};\n\nexport const createSourceFolder = async (\n projectRoot: string, // path inside project\n folder: SourceFolder,\n opt?: {\n frameworkOptions?: Record<string, unknown>;\n dependencies?: Record<string, string>;\n devDependencies?: Record<string, string>;\n },\n) => {\n const folderPath = resolve(projectRoot, folder.name);\n\n if (await pathExists(folderPath)) {\n throw new Error(`${folder.name} already exists`);\n }\n\n await copyFiles(resolve(TPL_DIR, \"@src\"), folderPath, {\n exclude: [/.+\\.hbs/],\n });\n\n const packageFile = resolve(projectRoot, \"package.json\");\n\n const packageImport = await import(packageFile, {\n with: { type: \"json\" },\n }).then((e) => e.default);\n\n const tsconfigFile = resolve(projectRoot, \"tsconfig.json\");\n\n const tsconfigImport = await import(tsconfigFile, {\n with: { type: \"json\" },\n }).then((e) => e.default);\n\n const compilerOptions = {\n ...tsconfigImport?.compilerOptions,\n // instruct TypeScript to preserve JSX\n jsx: \"preserve\",\n };\n\n const plugins: Array<Plugin> = [];\n const generators: Array<Generator> = [];\n\n const dependencies: Record<string, string> = {};\n const devDependencies: Record<string, string> = {};\n\n const framework: SourceFolder[\"framework\"] =\n folder.framework || DEFAULT_FRAMEWORK;\n\n if (framework === \"solid\") {\n Object.assign(dependencies, {\n \"@solidjs/router\": self.devDependencies[\"@solidjs/router\"],\n \"solid-js\": self.devDependencies[\"solid-js\"],\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/solid-generator\": SEMVER,\n \"vite-plugin-solid\": self.devDependencies[\"vite-plugin-solid\"],\n });\n\n plugins.push({\n importDeclaration: `import solidPlugin from \"vite-plugin-solid\";`,\n importName: \"solidPlugin\",\n options: folder.ssr ? \"{ ssr: true }\" : \"\",\n });\n\n generators.push({\n importDeclaration: `import solidGenerator from \"@kosmojs/solid-generator\";`,\n importName: \"solidGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n\n compilerOptions.jsxImportSource = \"solid-js\";\n } else if (framework === \"react\") {\n Object.assign(dependencies, {\n react: self.devDependencies.react,\n \"react-router\": self.devDependencies[\"react-router\"],\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/react-generator\": SEMVER,\n \"@vitejs/plugin-react\": self.devDependencies[\"@vitejs/plugin-react\"],\n \"@types/react\": self.devDependencies[\"@types/react\"],\n \"@types/react-dom\": self.devDependencies[\"@types/react-dom\"],\n \"react-dom\": self.devDependencies[\"react-dom\"],\n });\n\n plugins.push({\n importDeclaration: `import reactPlugin from \"@vitejs/plugin-react\";`,\n importName: \"reactPlugin\",\n options: \"\",\n });\n\n generators.push({\n importDeclaration: `import reactGenerator from \"@kosmojs/react-generator\";`,\n importName: \"reactGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n\n compilerOptions.jsxImportSource = \"react\";\n } else if (framework === \"vue\") {\n Object.assign(dependencies, {\n \"vue-router\": self.devDependencies[\"vue-router\"],\n vue: self.devDependencies.vue,\n });\n\n Object.assign(devDependencies, {\n \"@kosmojs/vue-generator\": SEMVER,\n \"@vitejs/plugin-vue\": self.devDependencies[\"@vitejs/plugin-vue\"],\n });\n\n plugins.push({\n importDeclaration: `import vuePlugin from \"@vitejs/plugin-vue\";`,\n importName: \"vuePlugin\",\n options: \"\",\n });\n\n generators.push({\n importDeclaration: `import vueGenerator from \"@kosmojs/vue-generator\";`,\n importName: \"vueGenerator\",\n options: opt?.frameworkOptions\n ? JSON.stringify(opt.frameworkOptions, null, 2)\n : \"\",\n });\n }\n\n if (folder.ssr) {\n generators.push({\n importDeclaration: `import ssrGenerator from \"@kosmojs/ssr-generator\";`,\n importName: \"ssrGenerator\",\n options: \"\",\n });\n Object.assign(dependencies, {\n \"path-to-regexp\": self.devDependencies[\"path-to-regexp\"],\n });\n Object.assign(devDependencies, {\n \"@kosmojs/ssr-generator\": SEMVER,\n });\n }\n\n const context = {\n folder: {\n base: DEFAULT_BASE,\n port: DEFAULT_PORT,\n ...folder,\n },\n defaults,\n plugins,\n generators,\n importPathmap: {\n core: [defaults.appPrefix, defaults.coreDir, defaults.apiDir].join(\"/\"),\n lib: [folder.name, defaults.apiLibDir].join(\"/\"),\n },\n };\n\n for (const [file, template] of [\n [`${defaults.configDir}/index.ts`, srcConfigTpl],\n [`${defaults.apiDir}/app.ts`, srcApiAppTpl],\n [`${defaults.apiDir}/router.ts`, srcApiRouterTpl],\n [`${defaults.apiDir}/server.ts`, srcApiServerTpl],\n [`${defaults.apiDir}/use.ts`, srcApiUseTpl],\n [\"vite.config.ts\", srcViteConfigTpl],\n // stub files for initial build to pass;\n // generators will fill them with appropriate content.\n [`${defaults.apiDir}/index/index.ts`, \"\"],\n ...([\"solid\", \"react\"].includes(framework)\n ? [\n [`${defaults.pagesDir}/index/index.tsx`, \"\"],\n [`${defaults.entryDir}/client.tsx`, \"\"],\n ]\n : []),\n ...([\"vue\"].includes(framework)\n ? [\n [`${defaults.pagesDir}/index/index.vue`, \"\"],\n [`${defaults.entryDir}/client.ts`, \"\"],\n ]\n : []),\n ]) {\n await renderToFile(resolve(folderPath, file), template, context);\n }\n\n const tsconfigUpdated = {\n ...tsconfigJson,\n ...tsconfigImport,\n compilerOptions: {\n ...compilerOptions,\n paths: {\n ...compilerOptions?.paths,\n [`${folder.name}/*`]: [\n `./${folder.name}/*`,\n `./${defaults.libDir}/${folder.name}/*`,\n ],\n },\n },\n };\n\n await writeFile(\n tsconfigFile,\n JSON.stringify(tsconfigUpdated, null, 2),\n \"utf8\",\n );\n\n const packageUpdated = {\n ...packageImport,\n dependencies: {\n ...packageImport.dependencies,\n ...dependencies,\n ...opt?.dependencies,\n },\n devDependencies: {\n ...packageImport.devDependencies,\n ...devDependencies,\n ...opt?.devDependencies,\n },\n };\n\n await writeFile(packageFile, JSON.stringify(packageUpdated, null, 2));\n};\n", "import createApp from \"{{importPathmap.core}}/app\";\n\nimport router from \"./router\";\n\nexport default () => {\n const app = createApp();\n\n // routes goes latest\n app.use(router.routes());\n\n return app;\n};\n\n/**\n * In dev mode, determines whether to pass the request to API handler or to Vite.\nexport const devMiddlewareFactory: import(\"@kosmojs/api\").DevMiddlewareFactory = (\n app,\n) => {\n return (req, res, next) => {\n return req.url?.startsWith(\"...\")\n ? app?.callback()(req, res) // send request to api handler\n : next(); // send request to vite dev server\n };\n};\n * */\n\n/**\n * In dev mode, used to cleanup before reloading api handler.\nexport const teardownHandler: import(\"@kosmojs/api\").TeardownHandler = () => {\n // close db connections, server sockets etc.\n};\n * */\n", "import { routerRoutes } from \"{{importPathmap.lib}}\";\n\nimport createRouter from \"{{importPathmap.core}}/router\";\n\nconst router = createRouter();\n\nfor (const { name, path, methods, middleware } of routerRoutes) {\n router.register(path, methods, middleware, { name });\n}\n\nexport default router;\n", "import createServer from \"{{importPathmap.core}}/server\";\nimport createApp from \"./app\";\n\ncreateServer(createApp);\n", "import globalMiddleware from \"{{defaults.appPrefix}}/core/api/use\";\n\nexport default [\n // Global middleware applied to all routes\n ...globalMiddleware,\n];\n", "export const baseurl = \"{{folder.base}}\";\nexport const apiurl = \"/api\"; // relative to baseurl\n", "import { join } from \"node:path\";\n\n{{#each plugins}}{{importDeclaration}}\n{{/each}}\nimport devPlugin, { apiGenerator, fetchGenerator } from \"@kosmojs/dev\";\n{{#each generators}}{{importDeclaration}}\n{{/each}}\n\nimport defineConfig from \"../vite.base\";\nimport { apiurl, baseurl } from \"./config\";\n\nexport default defineConfig(import.meta.dirname, {\n base: join(baseurl, \"/\"),\n server: {\n port: {{folder.port}},\n },\n plugins: [\n {{#each plugins}}{{importName}}({{options}}),\n {{/each}}\n devPlugin(apiurl, {\n generators: [\n apiGenerator(),\n fetchGenerator(),\n {{#each generators}}{{importName}}({{options}}),\n {{/each}}\n ],\n }),\n ],\n});\n"],
5
+ "mappings": "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",
6
6
  "names": ["resolve", "styleText", "packageFile", "styleText", "resolve", "folder"]
7
7
  }
package/pkg/cli/index.js CHANGED
@@ -3,14 +3,7 @@ import { access, constants, cp } from "node:fs/promises";
3
3
  import { basename } from "node:path";
4
4
  import { styleText } from "node:util";
5
5
  var CREATE_OPTIONS = ["project", "folder"];
6
- var FRAMEWORK_OPTIONS = [
7
- "none",
8
- "solid",
9
- "react",
10
- "vue"
11
- // TODO: implement svelte generator
12
- // "svelte",
13
- ];
6
+ var FRAMEWORK_OPTIONS = ["none", "solid", "react", "vue"];
14
7
  var NODE_VERSION = "22";
15
8
  var DEFAULT_DIST = "dist";
16
9
  var DEFAULT_BASE = "/";
@@ -337,6 +330,9 @@ var createSourceFolder = async (projectRoot, folder, opt) => {
337
330
  importName: "ssrGenerator",
338
331
  options: ""
339
332
  });
333
+ Object.assign(dependencies, {
334
+ "path-to-regexp": self.devDependencies["path-to-regexp"]
335
+ });
340
336
  Object.assign(devDependencies, {
341
337
  "@kosmojs/ssr-generator": SEMVER
342
338
  });