@visulima/api-platform 3.0.31 → 3.0.33

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.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,27 @@
1
+ ## @visulima/api-platform [3.0.33](https://github.com/visulima/visulima/compare/@visulima/api-platform@3.0.32...@visulima/api-platform@3.0.33) (2025-01-13)
2
+
3
+
4
+ ### Dependencies
5
+
6
+ * **@visulima/jsdoc-open-api:** upgraded to 2.0.71
7
+ * **@visulima/path:** upgraded to 1.3.3
8
+ * **@visulima/fs:** upgraded to 2.3.7
9
+
10
+ ## @visulima/api-platform [3.0.32](https://github.com/visulima/visulima/compare/@visulima/api-platform@3.0.31...@visulima/api-platform@3.0.32) (2025-01-12)
11
+
12
+ ### Bug Fixes
13
+
14
+ * **api-platform:** updated yaml to 2.7.0 and all dev deps ([7109f09](https://github.com/visulima/visulima/commit/7109f09ce8790dae1c6a683d6432ecc715d17e9f))
15
+
16
+
17
+ ### Dependencies
18
+
19
+ * **@visulima/connect:** upgraded to 3.0.17
20
+ * **@visulima/jsdoc-open-api:** upgraded to 2.0.70
21
+ * **@visulima/path:** upgraded to 1.3.2
22
+ * **@visulima/crud:** upgraded to 2.0.34
23
+ * **@visulima/fs:** upgraded to 2.3.6
24
+
1
25
  ## @visulima/api-platform [3.0.31](https://github.com/visulima/visulima/compare/@visulima/api-platform@3.0.30...@visulima/api-platform@3.0.31) (2025-01-08)
2
26
 
3
27
 
@@ -0,0 +1,6 @@
1
+ 'use strict';var child_process=require('child_process'),fs=require('fs'),ee=require('process'),path=require('@visulima/path'),d=require('chalk'),jsdocOpenApi=require('@visulima/jsdoc-open-api'),promises=require('fs/promises'),utils=require('@visulima/path/utils');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var ee__default=/*#__PURE__*/_interopDefault(ee);var d__default=/*#__PURE__*/_interopDefault(d);var oe=(e,t)=>{if(t.length===0)throw new Error("must include at least one key to map");let r=e.toString();return t.forEach(o=>{r=o.optional?r.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):r.replace("(?:([^\\/]+?))",`:${o.name}`);}),r.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/gu,"/")},_=oe;var se=(e,t)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let r="";t.length>0&&(r=_(e,t));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//u.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/gu,"$1").slice(1):r?r.slice(1):e.toString()},F=se;var ae=(e,t,r)=>{let o=e.route.stack.at(-1),s=t.map(i=>({in:"path",name:i.name,required:!i.optional})),a=e.route.stack.filter(i=>i.handle.metadata);if(a.length>1)throw new Error("Only one metadata middleware is allowed per route");let l=(r+e.route.path).replaceAll(/\/{2,}/gu,"/");return a.length===0?{method:o.method,path:l,pathParams:s}:{metadata:a[0].handle.metadata,method:o.method,path:l,pathParams:s}},O=(e,t,r,o)=>{if(o=[...o,...r.keys],r.name==="router"&&r.handle&&r.handle.stack!==void 0)for(let s of r.handle.stack)t=t||"",O(e,`${t}/${F(r.regexp,r.keys)}`,s,o);!r.route||r.route.stack.length===0||e.push(ae(r,o,t));},ne=e=>{let t=e._router||e.router,r=[];for(let o of t.stack)O(r,"",o,[]);return r},j=ne;var ie=e=>{let t=[];return j(e).forEach(r=>{t.push({file:"unknown",method:r.method.toUpperCase(),path:r.path,tags:[]});}),t},$=ie;var L=e=>e.replaceAll(/ \(.*\)/gu,"").trim(),I=e=>e.trim().split(" ")[1].slice(1,-1),pe=e=>{let r=e.printRoutes().replaceAll(/[─│└├]/gu," ").trimEnd().split(`
2
+ `),o=r.reduce((a,l,i)=>{let p=L(l);if(L(r[i-1]??"")===p){let P=a.filter(v=>v.index<i&&v.segment===p),{methods:D}=P.at(-1);return D!==null&&D.push(I(l)),a}let c=l.replaceAll(/ \(.*\)/gu,"").match(/ /gu);if(c===null)throw new Error("Invalid spaces");let n=c.length/4,m=l.includes("("),S=m?[I(l)]:null;return a.push({depth:n,index:i,isRoute:m,methods:S,segment:p}),a},[]),s=[];return o.filter(a=>a.isRoute).forEach(a=>{let i=[...o.filter(p=>p.index<a.index&&p.depth<a.depth).filter((p,f,c)=>!c.find(n=>n.depth===p.depth&&n.index>p.index)).map(p=>p.segment),a.segment].join("");if(a.methods===null)throw new Error("Invalid methods");a.methods.forEach(p=>{s.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),s},C=pe;var le=e=>{let r=e._core.router.routes,o=[];return [...r.keys()].forEach(s=>{r.get(s).routes.forEach(a=>{o.push({file:"unknown",method:a.route.method.toUpperCase(),path:a.path,tags:[]});});}),o},N=le;var ce=e=>{let t=[];return e.middleware.filter(r=>r.router).flatMap(r=>r.router.stack).forEach(r=>{t.push({file:"unknown",method:r.methods.join("|").toUpperCase(),path:r.path,tags:[]});}),t},M=ce;var W=/\.(js|ts|mjs|cjs)$/u,he=(e,t,r=!1)=>{e=path.toNamespacedPath(e);let o=path.toNamespacedPath(ee.cwd()),s=[],a=jsdocOpenApi.parseFile(e,jsdocOpenApi.jsDocumentCommentsToOpenApi,r);s=[...s,...a.map(p=>p.spec)];let l=jsdocOpenApi.parseFile(e,jsdocOpenApi.swaggerJsDocumentCommentsToOpenApi,r);s=[...s,...l.map(p=>p.spec)];let i=[];return s.length===0?(fs.readFileSync(e,"utf8").split(/\r?\n/u).forEach(f=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/u.exec(f);if(c){let[,n]=c;n==="GET"&&(n="GET|HEAD"),i.push({file:e.replace(`${o}/`,""),method:n,path:path.toNamespacedPath(e.replace(t,"").replace(W,"")),tags:[]});}}),i.length===0&&i.push({file:e.replace(`${o}/`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:path.toNamespacedPath(e.replace(t,"").replace(W,"")),tags:[]}),i):(s.forEach(p=>{Object.entries(p?.paths??{}).forEach(([c,n])=>{Object.entries(n).forEach(([S,P])=>{i.push({file:e.replace(`${o}/`,""),method:S.toUpperCase(),path:path.toNamespacedPath(c),tags:P.tags});});});}),i)},H=he;var ge=Object.defineProperty,ye=(e,t)=>ge(e,"name",{value:t,configurable:!0}),J=ye(e=>{if(!e||!(e instanceof URL)&&typeof e!="string")throw new TypeError("Path must be a non-empty string or URL.")},"assertValidFileOrDirectoryPath");var xe=Object.defineProperty,Ee=(e,t)=>xe(e,"name",{value:t,configurable:!0}),g=class extends Error{static{Ee(this,"WalkError");}root;constructor(t,r){super(`${t instanceof Error?t.message:t} for path "${r}"`),this.cause=t,this.root=r;}get name(){return "WalkError"}set name(t){throw new Error("Cannot overwrite name of WalkError")}};var we=Object.defineProperty,Se=(e,t)=>we(e,"name",{value:t,configurable:!0}),R=Se(e=>{let t=e.replace(/\.\*/g,".([^/]*)").replace(/\*\*/g,"(.*)").replace(/(?<!\.)\*(?!\*)/g,"([^/]*)").replace(/\?/g,"[^/]").replace(/\.(?!\*)/g,"\\.").replace(/\{/g,"(").replace(/\}/g,")").replace(/,/g,"|").replace(/\[!(.*?)\]/g,"[^$1]");return new RegExp(`^${t}$`)},"globToRegExp"),Pe=Object.defineProperty,Re=(e,t)=>Pe(e,"name",{value:t,configurable:!0}),y=Re((e,t,r,o)=>Array.isArray(t)&&t.length>0&&!t.some(s=>e.endsWith(s))||r&&!r.some(s=>s.test(e))?!1:!o?.some(s=>s.test(e)),"walkInclude");var Oe=Object.defineProperty,U=(e,t)=>Oe(e,"name",{value:t,configurable:!0}),je=U(async e=>{let t=path.normalize(e),r=path.basename(t),o=await promises.stat(t);return {isDirectory:o.isDirectory,isFile:o.isFile,isSymbolicLink:o.isSymbolicLink,name:r,path:t}},"_createWalkEntry");async function*E(e,{extensions:t,followSymlinks:r=!1,includeDirs:o=!0,includeFiles:s=!0,includeSymlinks:a=!0,match:l,maxDepth:i=Number.POSITIVE_INFINITY,skip:p}={}){if(J(e),i<0)return;let f=l?l.map(n=>typeof n=="string"?R(n):n):void 0,c=p?p.map(n=>typeof n=="string"?R(n):n):void 0;if(e=path.resolve(utils.toPath(e)),o&&y(e,t,f,c)&&(yield await je(e)),!(i<1||!y(e,void 0,void 0,c)))try{for await(let n of await promises.readdir(e,{withFileTypes:!0})){let m=path.join(e,n.name);if(n.isSymbolicLink())if(r)m=await promises.realpath(m);else if(a&&y(m,t,f,c))yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:m};else continue;n.isSymbolicLink()||n.isDirectory()?yield*E(m,{extensions:t,followSymlinks:r,includeDirs:o,includeFiles:s,includeSymlinks:a,match:f,maxDepth:i-1,skip:c}):n.isFile()&&s&&y(m,t,f,c)&&(yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:m});}}catch(n){throw n instanceof g?n:new g(n,e)}}U(E,"walk");var $e=Object.defineProperty,Le=(e,t)=>$e(e,"name",{value:t,configurable:!0}),k=Le(async(e,t={})=>{Array.isArray(t.extensions)||(t.extensions=["js","mjs","cjs","ts"]);let r=[];for await(let o of E(e,t))r.push(o.path);return r},"collect");var w=[".js",".ts",".mjs",".cjs"],B=e=>{let t=path.parse(e);for(;t.base&&t.root!==t.dir;){if(fs.readdirSync(t.dir).find(s=>s==="package.json"))return t.dir;t=path.parse(t.dir);}return null},Y=e=>{let t=`${e}/package.json`,{dependencies:r}=JSON.parse(fs.readFileSync(t).toString());return r?.express?"express":r?.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r?.next?"next":r?.["@hapi/hapi"]?"hapi":r?.fastify?"fastify":null},q=(e,t)=>Object.keys(e).length===0?null:t==="hapi"?typeof e.app.app=="string"?e.app:e:e.app??e;var X=e=>{try{return fs.statSync(e).isDirectory()}catch{return !1}},Me=async(e="")=>{let t=path.join(e,"pages/api");return !X(t)&&(t=path.join(e,"src/pages/api"),!X(t))?[]:k(t,{extensions:w,includeDirs:!1})},z=Me;var A=async(e,t,r)=>{if(t==="express")return $(e);if(t==="koa")return M(e);if(t==="hapi")return N(e);if(t==="fastify")return C(e);if(t==="next"){let o=await z(e);if(o.length===0)throw new Error(`No API routes found, in "${e}".`);return o.flatMap(s=>H(s,e,r))}return null};var Ke=(e,t)=>{let r=new Map;return e.forEach(o=>{let s=t(o),a=r.get(s);a?a.push(o):r.set(s,[o]);}),r},Q=Ke;var We=(e,t)=>{let r={ANY:d__default.default.redBright,DELETE:d__default.default.redBright,GET:d__default.default.blue,HEAD:d__default.default.hex("#6C7280"),OPTIONS:d__default.default.hex("#6C7280"),PATCH:d__default.default.yellow,POST:d__default.default.yellow,PUT:d__default.default.yellow},o;if(e==="GET|HEAD")o=`${d__default.default.blue("GET")}${d__default.default.grey("|HEAD")}`;else {let f=r[e](e);o=e==="GET"?`${f}${d__default.default.grey("|HEAD")}`:f;}let s=e==="GET"?6:14-e.length,a=Array.from({length:s}).fill(" ").join(""),l=process.stdout.columns-16-t.length-4,i=l>0?Array.from({length:l}).fill(".").join(""):"",p=t.split("/").map(f=>[":","["].includes(f[0]??"")?d__default.default.yellowBright(f):f).join("/");return ` ${o}${a}${p}${d__default.default.grey(i)}`},He=(e,t={})=>e.map(r=>{if(!(Array.isArray(t.methods)&&t.methods.includes(r.method)))return r.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(r.method="ANY"),We(r.method,r.path.replace("/pages",""))}).filter(Boolean),T=He;var Ge=async(e,t,r={})=>{let o=path.join(ee__default.default.cwd(),t);if(!fs.existsSync(o))throw new Error("No such file, invalid path provided.");let s=B(o);if(!s)throw new Error("Please initialize local package.json.");if(e===void 0){let l=Y(s);if(!l)throw new Error("Couldn't detect supported back-end framework.");e=l;}let a=null;if(e==="next")a=await A(o,"next",r.verbose??!1);else {if(!fs.statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!w.includes(path.extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let l=`${s}/.env`;fs.existsSync(l)&&(await import(`${s}/node_modules/dotenv/lib/main.js`)).config({path:l});let i=path.extname(o)===".ts",p=path.join(s,"node_modules/.bin/tsc");if(i&&!fs.existsSync(p))throw new Error(`Please install typescript in ${s}`);try{if(i)try{child_process.execSync(`${p} --outDir framework-list >&2`,{cwd:s});}catch(n){console.log(`TSC compilation failed. Please resolve issues in your project.
3
+ `),console.log(n),fs.rmSync(path.join(s,"framework-list"),{recursive:!0});}let f=i?path.join(s,"framework-list",o.replace(s,"").replace(".ts",".js")):o,{default:c}=await import(f);a=await A(["AsyncFunction","Function"].includes(c.constructor.name)?await c():q(c,e),e,r.verbose??!1);}finally{i&&fs.rmSync(path.join(s,"framework-list"),{recursive:!0});}}if(a===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(r.includePaths)&&r.includePaths.length>0&&(a=r.includePaths.flatMap(l=>a.filter(i=>i.path.startsWith(l)))),Array.isArray(r.excludePaths)&&r.excludePaths.length>0&&(a=r.excludePaths.flatMap(l=>a.filter(i=>!i.path.startsWith(l)))),typeof r.group=="string"&&r.group!==""){console.log();let l=Q(a,p=>r.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;l.forEach((p,f)=>{i>0&&console.log();let c=(ee__default.default.stdout.columns-16-f.length)/2,n=c>0?Array.from({length:c}).fill(" ").join(""):"";console.log(n+d__default.default.bold.underline(f)),T(p,r).forEach(m=>{console.log(m);}),i+=1;});}else console.log(),T(a,r).forEach(l=>{console.log(l);});console.log(`
4
+ Listed ${d__default.default.greenBright(String(a.length))} HTTP ${a.length===1?"route":"routes"}.
5
+ `);},mr=Ge;exports.a=mr;//# sourceMappingURL=chunk-3GRHE4LD.js.map
6
+ //# sourceMappingURL=chunk-3GRHE4LD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/framework/cli/command/list/routes/express/map-keys-to-path.ts","../src/framework/cli/command/list/routes/express/path-regex-parser.ts","../src/framework/cli/command/list/routes/express/express-path-parser.ts","../src/framework/cli/command/list/routes/express-routes.ts","../src/framework/cli/command/list/routes/fastify-routes.ts","../src/framework/cli/command/list/routes/hapi-routes.ts","../src/framework/cli/command/list/routes/koa-routes.ts","../src/framework/cli/command/list/routes/next/api-route-file-parser.ts","../src/framework/cli/command/list/routes/next/collect-api-route-files.ts","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/assertValidFileOrDirectoryPath-BWWgA1wj.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/WalkError-H9EuRv7O.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/walk-include-CMUSRa86.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/walk-CNcSYQVq.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/collect-BtDVJEOm.mjs","../src/framework/cli/command/list/utils.ts","../src/framework/cli/command/list/get-routes.ts","../src/framework/cli/command/list/routes/routes-group-by.ts","../src/framework/cli/command/list/routes/routes-render.ts","../src/framework/cli/command/list/list-command.ts"],"names":["mapKeysToPath","layerRegexPath","keys","convertedSubPath","key","map_keys_to_path_default","pathRegexParser","mappedPath","match","path_regex_parser_default","parseRouteLayer","layer","basePath","lastRequestHandler","pathParameters","filtered","element","path","traverse","routes","l","expressPathParser","app","router","express_path_parser_default","expressRoutes","route","express_routes_default","getSegment","line","getMethod","fastifyRoutes","lines","segments","allSegments","index","segment","entries","item","methods","spaces","depth","isRoute","seg","_index","previousArray","r","method","fastify_routes_default","hapiRoutes","coreRoutes","hapi_routes_default","koaRoutes","middlewareFunction","koa_routes_default","extensionRegex","apiRouteFileParser","apiRouteFile","cwd","verbose","toNamespacedPath","cwdPath","nodeCwd","specs","parsedJsDocumentFile","parseFile","jsDocumentCommentsToOpenApi","parsedSwaggerJsDocumentFile","swaggerJsDocumentCommentsToOpenApi","readFileSync","spec","pathSpec","methodSpec","api_route_file_parser_default","__defProp","__name","target","value","assertValidFileOrDirectoryPath","fileOrDirectoryPath","WalkError","cause","root","_name","__defProp$1","__name$1","globToRegExp","glob","reString","walkInclude","extensions","skip","extension","pattern","_createWalkEntry","normalizePath","normalize","name","basename","info","stat","walk","directory","followSymlinks","includeDirectories","includeFiles","includeSymlinks","maxDepth","mappedMatch","mappedSkip","resolve","toPath","entry","readdir","join","realpath","error","collect","options","ALLOWED_EXTENSIONS","getAppWorkingDirectoryPath","appFilePath","lastParsedPath","parse","readdirSync","getFrameworkName","packageJSONFilePath","dependencies","getApp","appExport","frameworkName","isDirectory","statSync","collectApiRouteFiles","apiFolderPath","collect_api_route_files_default","getRoutes","appOrPath","apiRouteFiles","routesGroupBy","list","keyGetter","map","collection","routes_group_by_default","renderRoute","routePath","colorMap","chalk","methodText","coloredMethod","spacesCount","dotsCount","dots","routeText","routesRender","routesMap","routes_render_default","listCommand","framework","frameworkPath","process","existsSync","appWorkingDirectoryPath","extname","environmentFilePath","isTypeScriptApp","tscPath","execSync","rmSync","appJsFilePath","defaultExport","ipath","epath","groupedMap","counter","groupedRoutes","renderedRoute","list_command_default"],"mappings":"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","file":"chunk-3GRHE4LD.js","sourcesContent":["import type { ExpressRegex, Key } from \"./types\";\n\n/**\n * Map's the keys/path variables to the regex inside a given path\n *\n * @param layerRegexPath The regex for a router with path parameters\n * @param keys The keys that represent the path parameters\n *\n * @returns The regex for a path variable converted to original string on the express route\n */\nconst mapKeysToPath = (layerRegexPath: ExpressRegex, keys: Key[]): string => {\n if (keys.length === 0) {\n throw new Error(\"must include at least one key to map\");\n }\n\n let convertedSubPath = layerRegexPath.toString();\n\n keys.forEach((key) => {\n convertedSubPath = key.optional\n ? convertedSubPath.replace(\"(?:\\\\/([^\\\\/]+?))?\\\\\", `/:${key.name}?`)\n : convertedSubPath.replace(\"(?:([^\\\\/]+?))\", `:${key.name}`);\n });\n\n return convertedSubPath\n .replace(\"/?(?=\\\\/|$)/i\", \"\")\n .replace(\"/^\", \"\")\n .replaceAll(\"\\\\\", \"\")\n .replaceAll(/\\/{2,}/gu, \"/\");\n};\n\nexport default mapKeysToPath;\n","import mapKeysToPath from \"./map-keys-to-path\";\nimport type { ExpressRegex, Key } from \"./types\";\n\n/** Parses an express layer's regex and converts it to the original format seen in code.\n *\n * @param layerRegexPath The layer's regex pattern\n * @param keys The keys that represent the layer's path parameters\n * @returns The path string for that layer\n * Code inspired and modify from:\n * https://github.com/expressjs/express/issues/3308#issuecomment-300957572\n */\nconst pathRegexParser = (layerRegexPath: ExpressRegex | string, keys: Key[]): string => {\n if (typeof layerRegexPath === \"string\") {\n return layerRegexPath;\n }\n\n if (layerRegexPath.fast_slash) {\n return \"\";\n }\n\n if (layerRegexPath.fast_star) {\n return \"*\";\n }\n\n let mappedPath = \"\";\n\n if (keys.length > 0) {\n mappedPath = mapKeysToPath(layerRegexPath, keys);\n }\n\n const match = /^\\/\\^((?:\\\\[$()*+./?[\\\\\\]^{|}]|[^$()*+./?[\\\\\\]^{|}])*)\\$\\//u.exec(\n layerRegexPath.toString().replace(\"\\\\/?\", \"\").replace(\"(?=\\\\/|$)\", \"$\"),\n ) as string[];\n\n if (Array.isArray(match) && match.length > 1) {\n return (match[1] as string).replaceAll(/\\\\(.)/gu, \"$1\").slice(1);\n }\n\n if (mappedPath) {\n return mappedPath.slice(1);\n }\n\n return layerRegexPath.toString();\n};\n\nexport default pathRegexParser;\n","import type { Express, Router } from \"express\";\n\nimport pathRegexParser from \"./path-regex-parser\";\nimport type { Key, Layer, Parameter, Route, RouteMetaData } from \"./types\";\n\n/**\n * Parses a route object. Route objects are the leafs of an express router tree\n *\n * @param layer The layer of this route object - represents the stack of middleware and other metadata\n * @param keys The full set of keys for this particular route\n * @param basePath The base path as it was initial declared for this route\n * @returns A ExpressPath object holding the metadata for a given route\n */\nconst parseRouteLayer = (layer: Required<Layer>, keys: Key[], basePath: string): RouteMetaData => {\n const lastRequestHandler = layer.route.stack.at(-1) as Layer;\n const pathParameters: Parameter[] = keys.map((key) => {\n return { in: \"path\", name: key.name, required: !key.optional };\n });\n\n const filtered = layer.route.stack.filter((element) => (element.handle as Route).metadata);\n\n if (filtered.length > 1) {\n throw new Error(\"Only one metadata middleware is allowed per route\");\n }\n\n const path = (basePath + layer.route.path).replaceAll(/\\/{2,}/gu, \"/\");\n\n if (filtered.length === 0) {\n return { method: lastRequestHandler.method, path, pathParams: pathParameters };\n }\n\n return {\n metadata: ((filtered[0] as Layer).handle as Route).metadata,\n method: lastRequestHandler.method,\n path,\n pathParams: pathParameters,\n };\n};\n\n/**\n * Recursive traversal method for the express router and middleware tree.\n *\n * @param routes The array of routes to add to\n * @param path The current path segment that we have traversed so far\n * @param layer The current 'layer' of the router tree\n * @param keys The keys for the parameter's in the current path branch of the traversal\n * @returns void - base case saves result to internal object\n */\nconst traverse = (routes: RouteMetaData[], path: string, layer: Layer, keys: Key[]): void => {\n // eslint-disable-next-line no-param-reassign\n keys = [...keys, ...layer.keys];\n\n if (layer.name === \"router\" && layer.handle && layer.handle.stack !== undefined) {\n for (const l of layer.handle.stack) {\n // eslint-disable-next-line no-param-reassign\n path = path || \"\";\n\n traverse(routes, `${path}/${pathRegexParser(layer.regexp, layer.keys)}`, l as Layer, keys);\n }\n }\n\n if (!layer.route || layer.route.stack.length === 0) {\n return;\n }\n\n routes.push(parseRouteLayer(layer as Required<Layer>, keys, path));\n};\n\n// @TODO use this to parse the express swagger\n\n/**\n * Parses an Express app and generates list of routes with metadata.\n *\n * Can Parse:\n * - Nested Routers and Complex Express Projects\n * - Optional parameters e.g. /:name?\n * - Complex Matching routes e.g. /ma*tch, /ex(ab)?mple\n * - Regex routes e.g. /\\/abc|\\/xyz/\n * - Array of paths e.g. app.get(['/abc', '/xyz']) -> /abc,xyz/\n *\n * @param app The Express app reference. Must be used after all routes have been attached\n *\n * @returns List of routes for this express app with meta-data that has been picked up\n */\nconst expressPathParser = (app: Express): RouteMetaData[] => {\n // eslint-disable-next-line no-underscore-dangle\n const router: Router = app._router || app.router;\n const routes: RouteMetaData[] = [];\n\n for (const layer of router.stack) {\n // @TODO: revisit this type assertion\n traverse(routes, \"\", layer as unknown as Layer, []);\n }\n\n return routes;\n};\n\nexport default expressPathParser;\n","import type { Express } from \"express\";\n\nimport expressPathParser from \"./express/express-path-parser\";\nimport type { RouteMetaData } from \"./express/types\";\nimport type { Route } from \"./types\";\n\nconst expressRoutes = (app: Express): Route[] => {\n const routes: Route[] = [];\n\n expressPathParser(app).forEach((route: RouteMetaData) => {\n routes.push({\n file: \"unknown\",\n method: route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default expressRoutes;\n","import type { FastifyInstance } from \"fastify\";\n\nimport type { Route } from \"./types\";\n\n// \"<spaces> activity (GET)\" -> \"activity\"\nconst getSegment = (line: string) => line.replaceAll(/ \\(.*\\)/gu, \"\").trim();\n\n// \"<spaces> activity (GET)\" -> \"GET\"\nconst getMethod = (line: string) => (line.trim().split(\" \")[1] as string).slice(1, -1);\n\ninterface Segment {\n depth: number;\n index: number;\n isRoute: boolean;\n methods: string[] | null;\n segment: string;\n}\n\nconst fastifyRoutes = (app: FastifyInstance): Route[] => {\n const printedRoutes = app\n .printRoutes()\n .replaceAll(/[─│└├]/gu, \" \")\n .trimEnd();\n\n const lines = printedRoutes.split(\"\\n\");\n\n // eslint-disable-next-line unicorn/no-array-reduce\n const segments = lines.reduce((allSegments: Segment[], line, index) => {\n const segment = getSegment(line);\n const previousSegment = getSegment(lines[index - 1] ?? \"\");\n\n if (previousSegment === segment) {\n const entries: Segment[] = allSegments.filter((item) => item.index < index && item.segment === segment);\n\n const { methods } = entries.at(-1) as Segment;\n\n if (methods !== null) {\n methods.push(getMethod(line));\n }\n\n return allSegments;\n }\n\n // spaces preceding segment / not counting single space between segment and (METHOD)\n const spaces = line.replaceAll(/ \\(.*\\)/gu, \"\").match(/ /gu);\n\n if (spaces === null) {\n throw new Error(\"Invalid spaces\");\n }\n\n const depth = spaces.length / 4;\n const isRoute = line.includes(\"(\");\n const methods = isRoute ? [getMethod(line)] : null;\n\n allSegments.push({\n depth,\n index,\n isRoute,\n methods,\n segment,\n });\n\n return allSegments;\n }, []);\n\n const routes: Route[] = [];\n\n segments\n .filter((item) => item.isRoute)\n .forEach((item) => {\n const ancestorSegments = segments\n .filter((seg) => seg.index < item.index && seg.depth < item.depth)\n // eslint-disable-next-line unicorn/prefer-array-some\n .filter((seg, _index, previousArray) => !previousArray.find((segment) => segment.depth === seg.depth && segment.index > seg.index));\n\n const route = [...ancestorSegments.map((r) => r.segment), item.segment].join(\"\");\n\n if (item.methods === null) {\n throw new Error(\"Invalid methods\");\n }\n\n item.methods.forEach((method: string) => {\n routes.push({\n file: \"unknown\",\n method: method.toUpperCase(),\n path: route,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default fastifyRoutes;\n","import type { Server } from \"@hapi/hapi\";\n\nimport type { Route } from \"./types\";\n\nconst hapiRoutes = (app: Server): Route[] => {\n // @ts-expect-error TS2339: Property '_core' does not exist on type 'Server'. Internal API.\n // eslint-disable-next-line no-underscore-dangle\n const core = app._core as any;\n const coreRoutes = core.router.routes;\n const routes: Route[] = [];\n\n [...coreRoutes.keys()].forEach((method: string) => {\n coreRoutes.get(method).routes.forEach((route: any) => {\n routes.push({\n file: \"unknown\",\n method: route.route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default hapiRoutes;\n","import type Koa from \"koa\";\n\nimport type { Route } from \"./types\";\n\nconst koaRoutes = (app: Koa): Route[] => {\n const routes: Route[] = [];\n\n app.middleware\n .filter((middlewareFunction) => (middlewareFunction as any).router)\n\n .flatMap((middlewareFunction) => (middlewareFunction as any).router.stack)\n .forEach((route) => {\n routes.push({\n file: \"unknown\",\n method: route.methods.join(\"|\").toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default koaRoutes;\n","import { readFileSync } from \"node:fs\";\nimport { cwd as nodeCwd } from \"node:process\";\n\nimport type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport { toNamespacedPath } from \"@visulima/path\";\n\nimport type { Route } from \"../types\";\n\n// eslint-disable-next-line regexp/no-unused-capturing-group\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/u;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwd: string, verbose = false): Route[] => {\n // eslint-disable-next-line no-param-reassign\n apiRouteFile = toNamespacedPath(apiRouteFile);\n\n const cwdPath = toNamespacedPath(nodeCwd());\n\n let specs: OpenApiObject[] = [];\n\n const parsedJsDocumentFile = parseFile(apiRouteFile, jsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];\n\n const parsedSwaggerJsDocumentFile = parseFile(apiRouteFile, swaggerJsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];\n\n const routes: Route[] = [];\n\n if (specs.length === 0) {\n const apiRouteFileContent = readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/u).forEach((line) => {\n const match = /[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/u.exec(line);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method as string,\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n\n return routes;\n }\n\n specs.forEach((spec) => {\n const paths = Object.entries(spec?.paths ?? {});\n\n paths.forEach(([path, pathSpec]) => {\n const methods = Object.entries(pathSpec);\n\n methods.forEach(([method, methodSpec]) => {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method.toUpperCase(),\n path: toNamespacedPath(path),\n tags: methodSpec.tags,\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","import { statSync } from \"node:fs\";\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/fs\";\nimport { join } from \"@visulima/path\";\n\nimport { ALLOWED_EXTENSIONS } from \"../../utils\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path = \"\"): Promise<string[]> => {\n let apiFolderPath = join(path, \"pages/api\");\n\n // src/pages will be ignored if pages is present in the root directory\n if (!isDirectory(apiFolderPath)) {\n apiFolderPath = join(path, \"src/pages/api\");\n\n if (!isDirectory(apiFolderPath)) {\n return [];\n }\n }\n\n return collect(apiFolderPath, {\n extensions: ALLOWED_EXTENSIONS,\n includeDirs: false,\n });\n};\n\nexport default collectApiRouteFiles;\n","var __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst assertValidFileOrDirectoryPath = /* @__PURE__ */ __name((fileOrDirectoryPath) => {\n if (!fileOrDirectoryPath || !(fileOrDirectoryPath instanceof URL) && typeof fileOrDirectoryPath !== \"string\") {\n throw new TypeError(\"Path must be a non-empty string or URL.\");\n }\n}, \"assertValidFileOrDirectoryPath\");\n\nexport { assertValidFileOrDirectoryPath as default };\n","var __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nclass WalkError extends Error {\n static {\n __name(this, \"WalkError\");\n }\n /** File path of the root that's being walked. */\n root;\n /** Constructs a new instance. */\n constructor(cause, root) {\n super(`${cause instanceof Error ? cause.message : cause} for path \"${root}\"`);\n this.cause = cause;\n this.root = root;\n }\n // eslint-disable-next-line class-methods-use-this\n get name() {\n return \"WalkError\";\n }\n // eslint-disable-next-line class-methods-use-this,@typescript-eslint/explicit-module-boundary-types\n set name(_name) {\n throw new Error(\"Cannot overwrite name of WalkError\");\n }\n}\n\nexport { WalkError as default };\n","var __defProp$1 = Object.defineProperty;\nvar __name$1 = (target, value) => __defProp$1(target, \"name\", { value, configurable: true });\nconst globToRegExp = /* @__PURE__ */ __name$1((glob) => {\n const reString = glob.replace(/\\.\\*/g, \".([^/]*)\").replace(/\\*\\*/g, \"(.*)\").replace(/(?<!\\.)\\*(?!\\*)/g, \"([^/]*)\").replace(/\\?/g, \"[^/]\").replace(/\\.(?!\\*)/g, \"\\\\.\").replace(/\\{/g, \"(\").replace(/\\}/g, \")\").replace(/,/g, \"|\").replace(/\\[!(.*?)\\]/g, \"[^$1]\");\n return new RegExp(`^${reString}$`);\n}, \"globToRegExp\");\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst walkInclude = /* @__PURE__ */ __name((path, extensions, match, skip) => {\n if (Array.isArray(extensions) && extensions.length > 0 && !extensions.some((extension) => path.endsWith(extension))) {\n return false;\n }\n if (match && !match.some((pattern) => pattern.test(path))) {\n return false;\n }\n return !skip?.some((pattern) => pattern.test(path));\n}, \"walkInclude\");\n\nexport { globToRegExp as g, walkInclude as w };\n","import { readdir, realpath, stat } from 'node:fs/promises';\nimport { resolve, join, normalize, basename } from '@visulima/path';\nimport { toPath } from '@visulima/path/utils';\nimport WalkError from './WalkError-H9EuRv7O.mjs';\nimport assertValidFileOrDirectoryPath from './assertValidFileOrDirectoryPath-BWWgA1wj.mjs';\nimport { g as globToRegExp, w as walkInclude } from './walk-include-CMUSRa86.mjs';\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst _createWalkEntry = /* @__PURE__ */ __name(async (path) => {\n const normalizePath = normalize(path);\n const name = basename(normalizePath);\n const info = await stat(normalizePath);\n return {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: info.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: info.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: info.isSymbolicLink,\n name,\n path: normalizePath\n };\n}, \"_createWalkEntry\");\nasync function* walk(directory, {\n extensions,\n followSymlinks = false,\n includeDirs: includeDirectories = true,\n includeFiles = true,\n includeSymlinks = true,\n match,\n maxDepth = Number.POSITIVE_INFINITY,\n skip\n} = {}) {\n assertValidFileOrDirectoryPath(directory);\n if (maxDepth < 0) {\n return;\n }\n const mappedMatch = match ? match.map((pattern) => typeof pattern === \"string\" ? globToRegExp(pattern) : pattern) : undefined;\n const mappedSkip = skip ? skip.map((pattern) => typeof pattern === \"string\" ? globToRegExp(pattern) : pattern) : undefined;\n directory = resolve(toPath(directory));\n if (includeDirectories && walkInclude(directory, extensions, mappedMatch, mappedSkip)) {\n yield await _createWalkEntry(directory);\n }\n if (maxDepth < 1 || !walkInclude(directory, undefined, undefined, mappedSkip)) {\n return;\n }\n try {\n for await (const entry of await readdir(directory, {\n withFileTypes: true\n })) {\n let path = join(directory, entry.name);\n if (entry.isSymbolicLink()) {\n if (followSymlinks) {\n path = await realpath(path);\n } else if (includeSymlinks && walkInclude(path, extensions, mappedMatch, mappedSkip)) {\n yield {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: entry.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: entry.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: entry.isSymbolicLink,\n name: entry.name,\n path\n };\n } else {\n continue;\n }\n }\n if (entry.isSymbolicLink() || entry.isDirectory()) {\n yield* walk(path, {\n extensions,\n followSymlinks,\n includeDirs: includeDirectories,\n includeFiles,\n includeSymlinks,\n match: mappedMatch,\n maxDepth: maxDepth - 1,\n skip: mappedSkip\n });\n } else if (entry.isFile() && includeFiles && walkInclude(path, extensions, mappedMatch, mappedSkip)) {\n yield {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: entry.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: entry.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: entry.isSymbolicLink,\n name: entry.name,\n path\n };\n }\n }\n } catch (error) {\n if (error instanceof WalkError) {\n throw error;\n }\n throw new WalkError(error, directory);\n }\n}\n__name(walk, \"walk\");\n\nexport { walk as default };\n","import walk from './walk-CNcSYQVq.mjs';\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst collect = /* @__PURE__ */ __name(async (directory, options = {}) => {\n if (!Array.isArray(options.extensions)) {\n options.extensions = [\"js\", \"mjs\", \"cjs\", \"ts\"];\n }\n const entries = [];\n for await (const entry of walk(directory, options)) {\n entries.push(entry.path);\n }\n return entries;\n}, \"collect\");\n\nexport { collect as default };\n","import { readdirSync, readFileSync } from \"node:fs\";\n\nimport { parse } from \"@visulima/path\";\nimport type { PackageJson } from \"type-fest\";\n\ninterface AppExport {\n [key: string]: any;\n app?: string | { app?: string };\n}\n\nexport const ALLOWED_EXTENSIONS = [\".js\", \".ts\", \".mjs\", \".cjs\"];\n\nexport const getAppWorkingDirectoryPath = (appFilePath: string): string | null => {\n let lastParsedPath = parse(appFilePath);\n\n // Once the following condition returns false it means we traversed the whole file system\n // eslint-disable-next-line no-loops/no-loops\n while (lastParsedPath.base && lastParsedPath.root !== lastParsedPath.dir) {\n const parentDirectionItems = readdirSync(lastParsedPath.dir);\n\n const packageJSON = parentDirectionItems.find((item) => item === \"package.json\");\n\n if (packageJSON) {\n return lastParsedPath.dir;\n }\n\n lastParsedPath = parse(lastParsedPath.dir);\n }\n\n return null;\n};\n\nexport const getFrameworkName = (directory: string): \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null => {\n const packageJSONFilePath = `${directory}/package.json`;\n\n const { dependencies } = JSON.parse(readFileSync(packageJSONFilePath).toString()) as PackageJson;\n\n if (dependencies?.express) {\n return \"express\";\n }\n\n if (dependencies?.koa && (dependencies[\"@koa/router\"] || dependencies[\"koa-router\"])) {\n return \"koa\";\n }\n\n if (dependencies?.next) {\n return \"next\";\n }\n\n if (dependencies?.[\"@hapi/hapi\"]) {\n return \"hapi\";\n }\n\n if (dependencies?.fastify) {\n return \"fastify\";\n }\n\n return null;\n};\n\nexport const getApp = (appExport: AppExport, frameworkName: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null): AppExport | string | null => {\n const isExportEmpty = Object.keys(appExport).length === 0;\n\n if (isExportEmpty) {\n return null;\n }\n\n if (frameworkName === \"hapi\") {\n if (typeof (appExport.app as { app?: string }).app === \"string\") {\n return appExport.app as { app: string };\n }\n\n return appExport;\n }\n\n return appExport.app ?? appExport;\n};\n","import type { Server } from \"@hapi/hapi\";\nimport type { Express } from \"express\";\nimport type { FastifyInstance } from \"fastify\";\nimport type Koa from \"koa\";\n\nimport expressRoutes from \"./routes/express-routes\";\nimport fastifyRoutes from \"./routes/fastify-routes\";\nimport hapiRoutes from \"./routes/hapi-routes\";\nimport koaRoutes from \"./routes/koa-routes\";\nimport apiRouteFileParser from \"./routes/next/api-route-file-parser\";\nimport collectApiRouteFiles from \"./routes/next/collect-api-route-files\";\nimport type { Route } from \"./routes/types\";\n\nexport type FrameworkName = \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | \"unknown\";\nexport const getRoutes = async (\n appOrPath: Express | FastifyInstance | Koa | Server | string,\n frameworkName: FrameworkName,\n verbose: boolean,\n): Promise<Route[] | null> => {\n if (frameworkName === \"express\") {\n return expressRoutes(appOrPath as Express);\n }\n\n if (frameworkName === \"koa\") {\n return koaRoutes(appOrPath as Koa);\n }\n\n if (frameworkName === \"hapi\") {\n return hapiRoutes(appOrPath as Server);\n }\n\n if (frameworkName === \"fastify\") {\n return fastifyRoutes(appOrPath as FastifyInstance);\n }\n\n if (frameworkName === \"next\") {\n const apiRouteFiles = await collectApiRouteFiles(appOrPath as string);\n\n if (apiRouteFiles.length === 0) {\n throw new Error(`No API routes found, in \"${appOrPath}\".`);\n }\n\n return apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, appOrPath as string, verbose));\n }\n\n return null;\n};\n","import type { Route } from \"./types\";\n\nconst routesGroupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map<string, Route[]>();\n\n list.forEach((item) => {\n const key = keyGetter(item);\n const collection = map.get(key);\n\n if (collection) {\n collection.push(item);\n } else {\n map.set(key, [item]);\n }\n });\n\n return map;\n};\n\nexport default routesGroupBy;\n","import chalk from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n ANY: chalk.redBright,\n DELETE: chalk.redBright,\n GET: chalk.blue,\n HEAD: chalk.hex(\"#6C7280\"),\n OPTIONS: chalk.hex(\"#6C7280\"),\n PATCH: chalk.yellow,\n POST: chalk.yellow,\n PUT: chalk.yellow,\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${chalk.blue(\"GET\")}${chalk.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${chalk.grey(\"|HEAD\")}` : coloredMethod;\n }\n\n const spacesCount = method === \"GET\" ? 6 : 14 - method.length;\n const spaces = Array.from({ length: spacesCount }).fill(\" \").join(\"\");\n\n const dotsCount = process.stdout.columns - 16 - routePath.length - 4;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\".\").join(\"\") : \"\";\n\n const routeText = routePath\n .split(\"/\")\n .map((segment) => {\n const isDynamicSegment = [\":\", \"[\"].includes(segment[0] ?? \"\");\n\n return isDynamicSegment ? chalk.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${chalk.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[] } = {}): (string | undefined)[] =>\n routesMap\n .map((route) => {\n if (Array.isArray(options.methods) && options.methods.includes(route.method)) {\n return;\n }\n\n if (route.method === \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\") {\n // eslint-disable-next-line no-param-reassign\n route.method = \"ANY\";\n }\n\n // eslint-disable-next-line consistent-return\n return renderRoute(route.method, route.path.replace(\"/pages\", \"\"));\n })\n .filter(Boolean);\n\nexport default routesRender;\n","import { execSync } from \"node:child_process\";\nimport { existsSync, rmSync, statSync } from \"node:fs\";\nimport process from \"node:process\";\n\nimport { extname, join } from \"@visulima/path\";\nimport chalk from \"chalk\";\n\nimport { getRoutes } from \"./get-routes\";\nimport routesGroupBy from \"./routes/routes-group-by\";\nimport routesRender from \"./routes/routes-render\";\nimport type { Route } from \"./routes/types\";\nimport { ALLOWED_EXTENSIONS, getApp, getAppWorkingDirectoryPath, getFrameworkName } from \"./utils\";\n\ninterface RenderOptions {\n excludePaths: string[];\n group: string;\n includePaths: string[];\n methods: string[];\n verbose: boolean;\n}\n\nconst listCommand = async (\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | undefined,\n path: string,\n options: Partial<RenderOptions> = {},\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Promise<void> => {\n const frameworkPath = join(process.cwd(), path);\n\n if (!existsSync(frameworkPath)) {\n throw new Error(\"No such file, invalid path provided.\");\n }\n\n const appWorkingDirectoryPath = getAppWorkingDirectoryPath(frameworkPath);\n\n if (!appWorkingDirectoryPath) {\n throw new Error(\"Please initialize local package.json.\");\n }\n\n if (framework === undefined) {\n const frameworkName = getFrameworkName(appWorkingDirectoryPath);\n\n if (!frameworkName) {\n throw new Error(\"Couldn't detect supported back-end framework.\");\n }\n\n // eslint-disable-next-line no-param-reassign\n framework = frameworkName;\n }\n\n let routes: Route[] | null = null;\n\n if (framework === \"next\") {\n routes = await getRoutes(frameworkPath, \"next\", options.verbose ?? false);\n } else {\n if (!statSync(frameworkPath).isFile()) {\n throw new Error(`${frameworkPath} is directory, but file expected.`);\n }\n\n if (!ALLOWED_EXTENSIONS.includes(extname(frameworkPath))) {\n throw new Error(\"Please specify application .ts/.js/.mjs/.cjs file.\");\n }\n\n const environmentFilePath = `${appWorkingDirectoryPath}/.env`;\n\n if (existsSync(environmentFilePath)) {\n // Loads environment vars in the current process so application\n // that depends on them can be loaded properly below\n const dotEnvironmentFilePath = `${appWorkingDirectoryPath}/node_modules/dotenv/lib/main.js`;\n const dotenv = await import(dotEnvironmentFilePath);\n\n dotenv.config({ path: environmentFilePath });\n }\n\n const isTypeScriptApp = extname(frameworkPath) === \".ts\";\n const tscPath = join(appWorkingDirectoryPath, \"node_modules/.bin/tsc\");\n\n if (isTypeScriptApp && !existsSync(tscPath)) {\n throw new Error(`Please install typescript in ${appWorkingDirectoryPath}`);\n }\n\n try {\n if (isTypeScriptApp) {\n // || rm -r ./framework-list removes framework-list directory in case tsc fails\n\n try {\n execSync(`${tscPath} --outDir framework-list >&2`, { cwd: appWorkingDirectoryPath });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log(\"TSC compilation failed. Please resolve issues in your project.\\n\");\n // eslint-disable-next-line no-console\n console.log(error);\n\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n\n const appJsFilePath = isTypeScriptApp\n ? join(appWorkingDirectoryPath, \"framework-list\", frameworkPath.replace(appWorkingDirectoryPath, \"\").replace(\".ts\", \".js\"))\n : frameworkPath;\n\n const { default: defaultExport } = await import(appJsFilePath);\n\n routes = await getRoutes(\n [\"AsyncFunction\", \"Function\"].includes(defaultExport.constructor.name as string) ? await defaultExport() : getApp(defaultExport, framework),\n framework,\n options.verbose ?? false,\n );\n } finally {\n if (isTypeScriptApp) {\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n }\n\n if (routes === null) {\n throw new Error(`Framework \"${framework}\" is not supported.`);\n }\n\n if (Array.isArray(options.includePaths) && options.includePaths.length > 0) {\n routes = options.includePaths.flatMap((ipath) => (routes as Route[]).filter((route) => route.path.startsWith(ipath)));\n }\n\n if (Array.isArray(options.excludePaths) && options.excludePaths.length > 0) {\n routes = options.excludePaths.flatMap((epath) => (routes as Route[]).filter((route) => !route.path.startsWith(epath)));\n }\n\n if (typeof options.group === \"string\" && options.group !== \"\") {\n // eslint-disable-next-line no-console\n console.log();\n\n const groupedMap = routesGroupBy(routes, (route) => {\n if (options.group === \"path\") {\n return route.path.replace(\"/pages\", \"\").split(\"/\")[1];\n }\n\n return route.tags[0] ?? \"unsorted\";\n });\n\n let counter = 0;\n\n groupedMap.forEach((groupedRoutes, key) => {\n if (counter > 0) {\n // eslint-disable-next-line no-console\n console.log();\n }\n\n const dotsCount = (process.stdout.columns - 16 - key.length) / 2;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\" \").join(\"\") : \"\";\n\n // eslint-disable-next-line no-console\n console.log(dots + chalk.bold.underline(key));\n\n routesRender(groupedRoutes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n } else {\n // eslint-disable-next-line no-console\n console.log();\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n }\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${chalk.greenBright(String(routes.length))} HTTP ${routes.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n"]}
@@ -0,0 +1,6 @@
1
+ import {execSync}from'node:child_process';import {existsSync,statSync,rmSync,readdirSync,readFileSync}from'node:fs';import te,{cwd}from'node:process';import {normalize,basename,resolve,join,extname,parse,toNamespacedPath}from'@visulima/path';import h from'chalk';import {parseFile,jsDocumentCommentsToOpenApi,swaggerJsDocumentCommentsToOpenApi}from'@visulima/jsdoc-open-api';import {stat,readdir,realpath}from'node:fs/promises';import {toPath}from'@visulima/path/utils';var se=(e,t)=>{if(t.length===0)throw new Error("must include at least one key to map");let r=e.toString();return t.forEach(o=>{r=o.optional?r.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):r.replace("(?:([^\\/]+?))",`:${o.name}`);}),r.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/gu,"/")},F=se;var ae=(e,t)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let r="";t.length>0&&(r=F(e,t));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//u.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/gu,"$1").slice(1):r?r.slice(1):e.toString()},O=ae;var ne=(e,t,r)=>{let o=e.route.stack.at(-1),s=t.map(i=>({in:"path",name:i.name,required:!i.optional})),a=e.route.stack.filter(i=>i.handle.metadata);if(a.length>1)throw new Error("Only one metadata middleware is allowed per route");let l=(r+e.route.path).replaceAll(/\/{2,}/gu,"/");return a.length===0?{method:o.method,path:l,pathParams:s}:{metadata:a[0].handle.metadata,method:o.method,path:l,pathParams:s}},j=(e,t,r,o)=>{if(o=[...o,...r.keys],r.name==="router"&&r.handle&&r.handle.stack!==void 0)for(let s of r.handle.stack)t=t||"",j(e,`${t}/${O(r.regexp,r.keys)}`,s,o);!r.route||r.route.stack.length===0||e.push(ne(r,o,t));},ie=e=>{let t=e._router||e.router,r=[];for(let o of t.stack)j(r,"",o,[]);return r},$=ie;var pe=e=>{let t=[];return $(e).forEach(r=>{t.push({file:"unknown",method:r.method.toUpperCase(),path:r.path,tags:[]});}),t},L=pe;var I=e=>e.replaceAll(/ \(.*\)/gu,"").trim(),C=e=>e.trim().split(" ")[1].slice(1,-1),le=e=>{let r=e.printRoutes().replaceAll(/[─│└├]/gu," ").trimEnd().split(`
2
+ `),o=r.reduce((a,l,i)=>{let p=I(l);if(I(r[i-1]??"")===p){let R=a.filter(_=>_.index<i&&_.segment===p),{methods:v}=R.at(-1);return v!==null&&v.push(C(l)),a}let c=l.replaceAll(/ \(.*\)/gu,"").match(/ /gu);if(c===null)throw new Error("Invalid spaces");let n=c.length/4,d=l.includes("("),P=d?[C(l)]:null;return a.push({depth:n,index:i,isRoute:d,methods:P,segment:p}),a},[]),s=[];return o.filter(a=>a.isRoute).forEach(a=>{let i=[...o.filter(p=>p.index<a.index&&p.depth<a.depth).filter((p,f,c)=>!c.find(n=>n.depth===p.depth&&n.index>p.index)).map(p=>p.segment),a.segment].join("");if(a.methods===null)throw new Error("Invalid methods");a.methods.forEach(p=>{s.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),s},N=le;var ce=e=>{let r=e._core.router.routes,o=[];return [...r.keys()].forEach(s=>{r.get(s).routes.forEach(a=>{o.push({file:"unknown",method:a.route.method.toUpperCase(),path:a.path,tags:[]});});}),o},M=ce;var fe=e=>{let t=[];return e.middleware.filter(r=>r.router).flatMap(r=>r.router.stack).forEach(r=>{t.push({file:"unknown",method:r.methods.join("|").toUpperCase(),path:r.path,tags:[]});}),t},K=fe;var H=/\.(js|ts|mjs|cjs)$/u,ge=(e,t,r=!1)=>{e=toNamespacedPath(e);let o=toNamespacedPath(cwd()),s=[],a=parseFile(e,jsDocumentCommentsToOpenApi,r);s=[...s,...a.map(p=>p.spec)];let l=parseFile(e,swaggerJsDocumentCommentsToOpenApi,r);s=[...s,...l.map(p=>p.spec)];let i=[];return s.length===0?(readFileSync(e,"utf8").split(/\r?\n/u).forEach(f=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/u.exec(f);if(c){let[,n]=c;n==="GET"&&(n="GET|HEAD"),i.push({file:e.replace(`${o}/`,""),method:n,path:toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]});}}),i.length===0&&i.push({file:e.replace(`${o}/`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]}),i):(s.forEach(p=>{Object.entries(p?.paths??{}).forEach(([c,n])=>{Object.entries(n).forEach(([P,R])=>{i.push({file:e.replace(`${o}/`,""),method:P.toUpperCase(),path:toNamespacedPath(c),tags:R.tags});});});}),i)},J=ge;var ye=Object.defineProperty,xe=(e,t)=>ye(e,"name",{value:t,configurable:!0}),U=xe(e=>{if(!e||!(e instanceof URL)&&typeof e!="string")throw new TypeError("Path must be a non-empty string or URL.")},"assertValidFileOrDirectoryPath");var Ee=Object.defineProperty,we=(e,t)=>Ee(e,"name",{value:t,configurable:!0}),y=class extends Error{static{we(this,"WalkError");}root;constructor(t,r){super(`${t instanceof Error?t.message:t} for path "${r}"`),this.cause=t,this.root=r;}get name(){return "WalkError"}set name(t){throw new Error("Cannot overwrite name of WalkError")}};var Se=Object.defineProperty,Pe=(e,t)=>Se(e,"name",{value:t,configurable:!0}),k=Pe(e=>{let t=e.replace(/\.\*/g,".([^/]*)").replace(/\*\*/g,"(.*)").replace(/(?<!\.)\*(?!\*)/g,"([^/]*)").replace(/\?/g,"[^/]").replace(/\.(?!\*)/g,"\\.").replace(/\{/g,"(").replace(/\}/g,")").replace(/,/g,"|").replace(/\[!(.*?)\]/g,"[^$1]");return new RegExp(`^${t}$`)},"globToRegExp"),Re=Object.defineProperty,ke=(e,t)=>Re(e,"name",{value:t,configurable:!0}),x=ke((e,t,r,o)=>Array.isArray(t)&&t.length>0&&!t.some(s=>e.endsWith(s))||r&&!r.some(s=>s.test(e))?!1:!o?.some(s=>s.test(e)),"walkInclude");var je=Object.defineProperty,G=(e,t)=>je(e,"name",{value:t,configurable:!0}),$e=G(async e=>{let t=normalize(e),r=basename(t),o=await stat(t);return {isDirectory:o.isDirectory,isFile:o.isFile,isSymbolicLink:o.isSymbolicLink,name:r,path:t}},"_createWalkEntry");async function*w(e,{extensions:t,followSymlinks:r=!1,includeDirs:o=!0,includeFiles:s=!0,includeSymlinks:a=!0,match:l,maxDepth:i=Number.POSITIVE_INFINITY,skip:p}={}){if(U(e),i<0)return;let f=l?l.map(n=>typeof n=="string"?k(n):n):void 0,c=p?p.map(n=>typeof n=="string"?k(n):n):void 0;if(e=resolve(toPath(e)),o&&x(e,t,f,c)&&(yield await $e(e)),!(i<1||!x(e,void 0,void 0,c)))try{for await(let n of await readdir(e,{withFileTypes:!0})){let d=join(e,n.name);if(n.isSymbolicLink())if(r)d=await realpath(d);else if(a&&x(d,t,f,c))yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d};else continue;n.isSymbolicLink()||n.isDirectory()?yield*w(d,{extensions:t,followSymlinks:r,includeDirs:o,includeFiles:s,includeSymlinks:a,match:f,maxDepth:i-1,skip:c}):n.isFile()&&s&&x(d,t,f,c)&&(yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d});}}catch(n){throw n instanceof y?n:new y(n,e)}}G(w,"walk");var Le=Object.defineProperty,Ie=(e,t)=>Le(e,"name",{value:t,configurable:!0}),A=Ie(async(e,t={})=>{Array.isArray(t.extensions)||(t.extensions=["js","mjs","cjs","ts"]);let r=[];for await(let o of w(e,t))r.push(o.path);return r},"collect");var S=[".js",".ts",".mjs",".cjs"],Y=e=>{let t=parse(e);for(;t.base&&t.root!==t.dir;){if(readdirSync(t.dir).find(s=>s==="package.json"))return t.dir;t=parse(t.dir);}return null},q=e=>{let t=`${e}/package.json`,{dependencies:r}=JSON.parse(readFileSync(t).toString());return r?.express?"express":r?.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r?.next?"next":r?.["@hapi/hapi"]?"hapi":r?.fastify?"fastify":null},V=(e,t)=>Object.keys(e).length===0?null:t==="hapi"?typeof e.app.app=="string"?e.app:e:e.app??e;var z=e=>{try{return statSync(e).isDirectory()}catch{return !1}},Ke=async(e="")=>{let t=join(e,"pages/api");return !z(t)&&(t=join(e,"src/pages/api"),!z(t))?[]:A(t,{extensions:S,includeDirs:!1})},Q=Ke;var T=async(e,t,r)=>{if(t==="express")return L(e);if(t==="koa")return K(e);if(t==="hapi")return M(e);if(t==="fastify")return N(e);if(t==="next"){let o=await Q(e);if(o.length===0)throw new Error(`No API routes found, in "${e}".`);return o.flatMap(s=>J(s,e,r))}return null};var We=(e,t)=>{let r=new Map;return e.forEach(o=>{let s=t(o),a=r.get(s);a?a.push(o):r.set(s,[o]);}),r},Z=We;var He=(e,t)=>{let r={ANY:h.redBright,DELETE:h.redBright,GET:h.blue,HEAD:h.hex("#6C7280"),OPTIONS:h.hex("#6C7280"),PATCH:h.yellow,POST:h.yellow,PUT:h.yellow},o;if(e==="GET|HEAD")o=`${h.blue("GET")}${h.grey("|HEAD")}`;else {let f=r[e](e);o=e==="GET"?`${f}${h.grey("|HEAD")}`:f;}let s=e==="GET"?6:14-e.length,a=Array.from({length:s}).fill(" ").join(""),l=process.stdout.columns-16-t.length-4,i=l>0?Array.from({length:l}).fill(".").join(""):"",p=t.split("/").map(f=>[":","["].includes(f[0]??"")?h.yellowBright(f):f).join("/");return ` ${o}${a}${p}${h.grey(i)}`},Je=(e,t={})=>e.map(r=>{if(!(Array.isArray(t.methods)&&t.methods.includes(r.method)))return r.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(r.method="ANY"),He(r.method,r.path.replace("/pages",""))}).filter(Boolean),b=Je;var Be=async(e,t,r={})=>{let o=join(te.cwd(),t);if(!existsSync(o))throw new Error("No such file, invalid path provided.");let s=Y(o);if(!s)throw new Error("Please initialize local package.json.");if(e===void 0){let l=q(s);if(!l)throw new Error("Couldn't detect supported back-end framework.");e=l;}let a=null;if(e==="next")a=await T(o,"next",r.verbose??!1);else {if(!statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!S.includes(extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let l=`${s}/.env`;existsSync(l)&&(await import(`${s}/node_modules/dotenv/lib/main.js`)).config({path:l});let i=extname(o)===".ts",p=join(s,"node_modules/.bin/tsc");if(i&&!existsSync(p))throw new Error(`Please install typescript in ${s}`);try{if(i)try{execSync(`${p} --outDir framework-list >&2`,{cwd:s});}catch(n){console.log(`TSC compilation failed. Please resolve issues in your project.
3
+ `),console.log(n),rmSync(join(s,"framework-list"),{recursive:!0});}let f=i?join(s,"framework-list",o.replace(s,"").replace(".ts",".js")):o,{default:c}=await import(f);a=await T(["AsyncFunction","Function"].includes(c.constructor.name)?await c():V(c,e),e,r.verbose??!1);}finally{i&&rmSync(join(s,"framework-list"),{recursive:!0});}}if(a===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(r.includePaths)&&r.includePaths.length>0&&(a=r.includePaths.flatMap(l=>a.filter(i=>i.path.startsWith(l)))),Array.isArray(r.excludePaths)&&r.excludePaths.length>0&&(a=r.excludePaths.flatMap(l=>a.filter(i=>!i.path.startsWith(l)))),typeof r.group=="string"&&r.group!==""){console.log();let l=Z(a,p=>r.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;l.forEach((p,f)=>{i>0&&console.log();let c=(te.stdout.columns-16-f.length)/2,n=c>0?Array.from({length:c}).fill(" ").join(""):"";console.log(n+h.bold.underline(f)),b(p,r).forEach(d=>{console.log(d);}),i+=1;});}else console.log(),b(a,r).forEach(l=>{console.log(l);});console.log(`
4
+ Listed ${h.greenBright(String(a.length))} HTTP ${a.length===1?"route":"routes"}.
5
+ `);},dr=Be;export{dr as a};//# sourceMappingURL=chunk-MDDP5HI3.mjs.map
6
+ //# sourceMappingURL=chunk-MDDP5HI3.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/framework/cli/command/list/routes/express/map-keys-to-path.ts","../src/framework/cli/command/list/routes/express/path-regex-parser.ts","../src/framework/cli/command/list/routes/express/express-path-parser.ts","../src/framework/cli/command/list/routes/express-routes.ts","../src/framework/cli/command/list/routes/fastify-routes.ts","../src/framework/cli/command/list/routes/hapi-routes.ts","../src/framework/cli/command/list/routes/koa-routes.ts","../src/framework/cli/command/list/routes/next/api-route-file-parser.ts","../src/framework/cli/command/list/routes/next/collect-api-route-files.ts","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/assertValidFileOrDirectoryPath-BWWgA1wj.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/WalkError-H9EuRv7O.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/walk-include-CMUSRa86.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/walk-CNcSYQVq.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.6/node_modules/@visulima/fs/dist/packem_shared/collect-BtDVJEOm.mjs","../src/framework/cli/command/list/utils.ts","../src/framework/cli/command/list/get-routes.ts","../src/framework/cli/command/list/routes/routes-group-by.ts","../src/framework/cli/command/list/routes/routes-render.ts","../src/framework/cli/command/list/list-command.ts"],"names":["mapKeysToPath","layerRegexPath","keys","convertedSubPath","key","map_keys_to_path_default","pathRegexParser","mappedPath","match","path_regex_parser_default","parseRouteLayer","layer","basePath","lastRequestHandler","pathParameters","filtered","element","path","traverse","routes","l","expressPathParser","app","router","express_path_parser_default","expressRoutes","route","express_routes_default","getSegment","line","getMethod","fastifyRoutes","lines","segments","allSegments","index","segment","entries","item","methods","spaces","depth","isRoute","seg","_index","previousArray","r","method","fastify_routes_default","hapiRoutes","coreRoutes","hapi_routes_default","koaRoutes","middlewareFunction","koa_routes_default","extensionRegex","apiRouteFileParser","apiRouteFile","cwd","verbose","toNamespacedPath","cwdPath","nodeCwd","specs","parsedJsDocumentFile","parseFile","jsDocumentCommentsToOpenApi","parsedSwaggerJsDocumentFile","swaggerJsDocumentCommentsToOpenApi","readFileSync","spec","pathSpec","methodSpec","api_route_file_parser_default","__defProp","__name","target","value","assertValidFileOrDirectoryPath","fileOrDirectoryPath","WalkError","cause","root","_name","__defProp$1","__name$1","globToRegExp","glob","reString","walkInclude","extensions","skip","extension","pattern","_createWalkEntry","normalizePath","normalize","name","basename","info","stat","walk","directory","followSymlinks","includeDirectories","includeFiles","includeSymlinks","maxDepth","mappedMatch","mappedSkip","resolve","toPath","entry","readdir","join","realpath","error","collect","options","ALLOWED_EXTENSIONS","getAppWorkingDirectoryPath","appFilePath","lastParsedPath","parse","readdirSync","getFrameworkName","packageJSONFilePath","dependencies","getApp","appExport","frameworkName","isDirectory","statSync","collectApiRouteFiles","apiFolderPath","collect_api_route_files_default","getRoutes","appOrPath","apiRouteFiles","routesGroupBy","list","keyGetter","map","collection","routes_group_by_default","renderRoute","routePath","colorMap","chalk","methodText","coloredMethod","spacesCount","dotsCount","dots","routeText","routesRender","routesMap","routes_render_default","listCommand","framework","frameworkPath","process","existsSync","appWorkingDirectoryPath","extname","environmentFilePath","isTypeScriptApp","tscPath","execSync","rmSync","appJsFilePath","defaultExport","ipath","epath","groupedMap","counter","groupedRoutes","renderedRoute","list_command_default"],"mappings":"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","file":"chunk-MDDP5HI3.mjs","sourcesContent":["import type { ExpressRegex, Key } from \"./types\";\n\n/**\n * Map's the keys/path variables to the regex inside a given path\n *\n * @param layerRegexPath The regex for a router with path parameters\n * @param keys The keys that represent the path parameters\n *\n * @returns The regex for a path variable converted to original string on the express route\n */\nconst mapKeysToPath = (layerRegexPath: ExpressRegex, keys: Key[]): string => {\n if (keys.length === 0) {\n throw new Error(\"must include at least one key to map\");\n }\n\n let convertedSubPath = layerRegexPath.toString();\n\n keys.forEach((key) => {\n convertedSubPath = key.optional\n ? convertedSubPath.replace(\"(?:\\\\/([^\\\\/]+?))?\\\\\", `/:${key.name}?`)\n : convertedSubPath.replace(\"(?:([^\\\\/]+?))\", `:${key.name}`);\n });\n\n return convertedSubPath\n .replace(\"/?(?=\\\\/|$)/i\", \"\")\n .replace(\"/^\", \"\")\n .replaceAll(\"\\\\\", \"\")\n .replaceAll(/\\/{2,}/gu, \"/\");\n};\n\nexport default mapKeysToPath;\n","import mapKeysToPath from \"./map-keys-to-path\";\nimport type { ExpressRegex, Key } from \"./types\";\n\n/** Parses an express layer's regex and converts it to the original format seen in code.\n *\n * @param layerRegexPath The layer's regex pattern\n * @param keys The keys that represent the layer's path parameters\n * @returns The path string for that layer\n * Code inspired and modify from:\n * https://github.com/expressjs/express/issues/3308#issuecomment-300957572\n */\nconst pathRegexParser = (layerRegexPath: ExpressRegex | string, keys: Key[]): string => {\n if (typeof layerRegexPath === \"string\") {\n return layerRegexPath;\n }\n\n if (layerRegexPath.fast_slash) {\n return \"\";\n }\n\n if (layerRegexPath.fast_star) {\n return \"*\";\n }\n\n let mappedPath = \"\";\n\n if (keys.length > 0) {\n mappedPath = mapKeysToPath(layerRegexPath, keys);\n }\n\n const match = /^\\/\\^((?:\\\\[$()*+./?[\\\\\\]^{|}]|[^$()*+./?[\\\\\\]^{|}])*)\\$\\//u.exec(\n layerRegexPath.toString().replace(\"\\\\/?\", \"\").replace(\"(?=\\\\/|$)\", \"$\"),\n ) as string[];\n\n if (Array.isArray(match) && match.length > 1) {\n return (match[1] as string).replaceAll(/\\\\(.)/gu, \"$1\").slice(1);\n }\n\n if (mappedPath) {\n return mappedPath.slice(1);\n }\n\n return layerRegexPath.toString();\n};\n\nexport default pathRegexParser;\n","import type { Express, Router } from \"express\";\n\nimport pathRegexParser from \"./path-regex-parser\";\nimport type { Key, Layer, Parameter, Route, RouteMetaData } from \"./types\";\n\n/**\n * Parses a route object. Route objects are the leafs of an express router tree\n *\n * @param layer The layer of this route object - represents the stack of middleware and other metadata\n * @param keys The full set of keys for this particular route\n * @param basePath The base path as it was initial declared for this route\n * @returns A ExpressPath object holding the metadata for a given route\n */\nconst parseRouteLayer = (layer: Required<Layer>, keys: Key[], basePath: string): RouteMetaData => {\n const lastRequestHandler = layer.route.stack.at(-1) as Layer;\n const pathParameters: Parameter[] = keys.map((key) => {\n return { in: \"path\", name: key.name, required: !key.optional };\n });\n\n const filtered = layer.route.stack.filter((element) => (element.handle as Route).metadata);\n\n if (filtered.length > 1) {\n throw new Error(\"Only one metadata middleware is allowed per route\");\n }\n\n const path = (basePath + layer.route.path).replaceAll(/\\/{2,}/gu, \"/\");\n\n if (filtered.length === 0) {\n return { method: lastRequestHandler.method, path, pathParams: pathParameters };\n }\n\n return {\n metadata: ((filtered[0] as Layer).handle as Route).metadata,\n method: lastRequestHandler.method,\n path,\n pathParams: pathParameters,\n };\n};\n\n/**\n * Recursive traversal method for the express router and middleware tree.\n *\n * @param routes The array of routes to add to\n * @param path The current path segment that we have traversed so far\n * @param layer The current 'layer' of the router tree\n * @param keys The keys for the parameter's in the current path branch of the traversal\n * @returns void - base case saves result to internal object\n */\nconst traverse = (routes: RouteMetaData[], path: string, layer: Layer, keys: Key[]): void => {\n // eslint-disable-next-line no-param-reassign\n keys = [...keys, ...layer.keys];\n\n if (layer.name === \"router\" && layer.handle && layer.handle.stack !== undefined) {\n for (const l of layer.handle.stack) {\n // eslint-disable-next-line no-param-reassign\n path = path || \"\";\n\n traverse(routes, `${path}/${pathRegexParser(layer.regexp, layer.keys)}`, l as Layer, keys);\n }\n }\n\n if (!layer.route || layer.route.stack.length === 0) {\n return;\n }\n\n routes.push(parseRouteLayer(layer as Required<Layer>, keys, path));\n};\n\n// @TODO use this to parse the express swagger\n\n/**\n * Parses an Express app and generates list of routes with metadata.\n *\n * Can Parse:\n * - Nested Routers and Complex Express Projects\n * - Optional parameters e.g. /:name?\n * - Complex Matching routes e.g. /ma*tch, /ex(ab)?mple\n * - Regex routes e.g. /\\/abc|\\/xyz/\n * - Array of paths e.g. app.get(['/abc', '/xyz']) -> /abc,xyz/\n *\n * @param app The Express app reference. Must be used after all routes have been attached\n *\n * @returns List of routes for this express app with meta-data that has been picked up\n */\nconst expressPathParser = (app: Express): RouteMetaData[] => {\n // eslint-disable-next-line no-underscore-dangle\n const router: Router = app._router || app.router;\n const routes: RouteMetaData[] = [];\n\n for (const layer of router.stack) {\n // @TODO: revisit this type assertion\n traverse(routes, \"\", layer as unknown as Layer, []);\n }\n\n return routes;\n};\n\nexport default expressPathParser;\n","import type { Express } from \"express\";\n\nimport expressPathParser from \"./express/express-path-parser\";\nimport type { RouteMetaData } from \"./express/types\";\nimport type { Route } from \"./types\";\n\nconst expressRoutes = (app: Express): Route[] => {\n const routes: Route[] = [];\n\n expressPathParser(app).forEach((route: RouteMetaData) => {\n routes.push({\n file: \"unknown\",\n method: route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default expressRoutes;\n","import type { FastifyInstance } from \"fastify\";\n\nimport type { Route } from \"./types\";\n\n// \"<spaces> activity (GET)\" -> \"activity\"\nconst getSegment = (line: string) => line.replaceAll(/ \\(.*\\)/gu, \"\").trim();\n\n// \"<spaces> activity (GET)\" -> \"GET\"\nconst getMethod = (line: string) => (line.trim().split(\" \")[1] as string).slice(1, -1);\n\ninterface Segment {\n depth: number;\n index: number;\n isRoute: boolean;\n methods: string[] | null;\n segment: string;\n}\n\nconst fastifyRoutes = (app: FastifyInstance): Route[] => {\n const printedRoutes = app\n .printRoutes()\n .replaceAll(/[─│└├]/gu, \" \")\n .trimEnd();\n\n const lines = printedRoutes.split(\"\\n\");\n\n // eslint-disable-next-line unicorn/no-array-reduce\n const segments = lines.reduce((allSegments: Segment[], line, index) => {\n const segment = getSegment(line);\n const previousSegment = getSegment(lines[index - 1] ?? \"\");\n\n if (previousSegment === segment) {\n const entries: Segment[] = allSegments.filter((item) => item.index < index && item.segment === segment);\n\n const { methods } = entries.at(-1) as Segment;\n\n if (methods !== null) {\n methods.push(getMethod(line));\n }\n\n return allSegments;\n }\n\n // spaces preceding segment / not counting single space between segment and (METHOD)\n const spaces = line.replaceAll(/ \\(.*\\)/gu, \"\").match(/ /gu);\n\n if (spaces === null) {\n throw new Error(\"Invalid spaces\");\n }\n\n const depth = spaces.length / 4;\n const isRoute = line.includes(\"(\");\n const methods = isRoute ? [getMethod(line)] : null;\n\n allSegments.push({\n depth,\n index,\n isRoute,\n methods,\n segment,\n });\n\n return allSegments;\n }, []);\n\n const routes: Route[] = [];\n\n segments\n .filter((item) => item.isRoute)\n .forEach((item) => {\n const ancestorSegments = segments\n .filter((seg) => seg.index < item.index && seg.depth < item.depth)\n // eslint-disable-next-line unicorn/prefer-array-some\n .filter((seg, _index, previousArray) => !previousArray.find((segment) => segment.depth === seg.depth && segment.index > seg.index));\n\n const route = [...ancestorSegments.map((r) => r.segment), item.segment].join(\"\");\n\n if (item.methods === null) {\n throw new Error(\"Invalid methods\");\n }\n\n item.methods.forEach((method: string) => {\n routes.push({\n file: \"unknown\",\n method: method.toUpperCase(),\n path: route,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default fastifyRoutes;\n","import type { Server } from \"@hapi/hapi\";\n\nimport type { Route } from \"./types\";\n\nconst hapiRoutes = (app: Server): Route[] => {\n // @ts-expect-error TS2339: Property '_core' does not exist on type 'Server'. Internal API.\n // eslint-disable-next-line no-underscore-dangle\n const core = app._core as any;\n const coreRoutes = core.router.routes;\n const routes: Route[] = [];\n\n [...coreRoutes.keys()].forEach((method: string) => {\n coreRoutes.get(method).routes.forEach((route: any) => {\n routes.push({\n file: \"unknown\",\n method: route.route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default hapiRoutes;\n","import type Koa from \"koa\";\n\nimport type { Route } from \"./types\";\n\nconst koaRoutes = (app: Koa): Route[] => {\n const routes: Route[] = [];\n\n app.middleware\n .filter((middlewareFunction) => (middlewareFunction as any).router)\n\n .flatMap((middlewareFunction) => (middlewareFunction as any).router.stack)\n .forEach((route) => {\n routes.push({\n file: \"unknown\",\n method: route.methods.join(\"|\").toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default koaRoutes;\n","import { readFileSync } from \"node:fs\";\nimport { cwd as nodeCwd } from \"node:process\";\n\nimport type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport { toNamespacedPath } from \"@visulima/path\";\n\nimport type { Route } from \"../types\";\n\n// eslint-disable-next-line regexp/no-unused-capturing-group\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/u;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwd: string, verbose = false): Route[] => {\n // eslint-disable-next-line no-param-reassign\n apiRouteFile = toNamespacedPath(apiRouteFile);\n\n const cwdPath = toNamespacedPath(nodeCwd());\n\n let specs: OpenApiObject[] = [];\n\n const parsedJsDocumentFile = parseFile(apiRouteFile, jsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];\n\n const parsedSwaggerJsDocumentFile = parseFile(apiRouteFile, swaggerJsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];\n\n const routes: Route[] = [];\n\n if (specs.length === 0) {\n const apiRouteFileContent = readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/u).forEach((line) => {\n const match = /[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/u.exec(line);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method as string,\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n\n return routes;\n }\n\n specs.forEach((spec) => {\n const paths = Object.entries(spec?.paths ?? {});\n\n paths.forEach(([path, pathSpec]) => {\n const methods = Object.entries(pathSpec);\n\n methods.forEach(([method, methodSpec]) => {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method.toUpperCase(),\n path: toNamespacedPath(path),\n tags: methodSpec.tags,\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","import { statSync } from \"node:fs\";\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/fs\";\nimport { join } from \"@visulima/path\";\n\nimport { ALLOWED_EXTENSIONS } from \"../../utils\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path = \"\"): Promise<string[]> => {\n let apiFolderPath = join(path, \"pages/api\");\n\n // src/pages will be ignored if pages is present in the root directory\n if (!isDirectory(apiFolderPath)) {\n apiFolderPath = join(path, \"src/pages/api\");\n\n if (!isDirectory(apiFolderPath)) {\n return [];\n }\n }\n\n return collect(apiFolderPath, {\n extensions: ALLOWED_EXTENSIONS,\n includeDirs: false,\n });\n};\n\nexport default collectApiRouteFiles;\n","var __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst assertValidFileOrDirectoryPath = /* @__PURE__ */ __name((fileOrDirectoryPath) => {\n if (!fileOrDirectoryPath || !(fileOrDirectoryPath instanceof URL) && typeof fileOrDirectoryPath !== \"string\") {\n throw new TypeError(\"Path must be a non-empty string or URL.\");\n }\n}, \"assertValidFileOrDirectoryPath\");\n\nexport { assertValidFileOrDirectoryPath as default };\n","var __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nclass WalkError extends Error {\n static {\n __name(this, \"WalkError\");\n }\n /** File path of the root that's being walked. */\n root;\n /** Constructs a new instance. */\n constructor(cause, root) {\n super(`${cause instanceof Error ? cause.message : cause} for path \"${root}\"`);\n this.cause = cause;\n this.root = root;\n }\n // eslint-disable-next-line class-methods-use-this\n get name() {\n return \"WalkError\";\n }\n // eslint-disable-next-line class-methods-use-this,@typescript-eslint/explicit-module-boundary-types\n set name(_name) {\n throw new Error(\"Cannot overwrite name of WalkError\");\n }\n}\n\nexport { WalkError as default };\n","var __defProp$1 = Object.defineProperty;\nvar __name$1 = (target, value) => __defProp$1(target, \"name\", { value, configurable: true });\nconst globToRegExp = /* @__PURE__ */ __name$1((glob) => {\n const reString = glob.replace(/\\.\\*/g, \".([^/]*)\").replace(/\\*\\*/g, \"(.*)\").replace(/(?<!\\.)\\*(?!\\*)/g, \"([^/]*)\").replace(/\\?/g, \"[^/]\").replace(/\\.(?!\\*)/g, \"\\\\.\").replace(/\\{/g, \"(\").replace(/\\}/g, \")\").replace(/,/g, \"|\").replace(/\\[!(.*?)\\]/g, \"[^$1]\");\n return new RegExp(`^${reString}$`);\n}, \"globToRegExp\");\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst walkInclude = /* @__PURE__ */ __name((path, extensions, match, skip) => {\n if (Array.isArray(extensions) && extensions.length > 0 && !extensions.some((extension) => path.endsWith(extension))) {\n return false;\n }\n if (match && !match.some((pattern) => pattern.test(path))) {\n return false;\n }\n return !skip?.some((pattern) => pattern.test(path));\n}, \"walkInclude\");\n\nexport { globToRegExp as g, walkInclude as w };\n","import { readdir, realpath, stat } from 'node:fs/promises';\nimport { resolve, join, normalize, basename } from '@visulima/path';\nimport { toPath } from '@visulima/path/utils';\nimport WalkError from './WalkError-H9EuRv7O.mjs';\nimport assertValidFileOrDirectoryPath from './assertValidFileOrDirectoryPath-BWWgA1wj.mjs';\nimport { g as globToRegExp, w as walkInclude } from './walk-include-CMUSRa86.mjs';\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst _createWalkEntry = /* @__PURE__ */ __name(async (path) => {\n const normalizePath = normalize(path);\n const name = basename(normalizePath);\n const info = await stat(normalizePath);\n return {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: info.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: info.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: info.isSymbolicLink,\n name,\n path: normalizePath\n };\n}, \"_createWalkEntry\");\nasync function* walk(directory, {\n extensions,\n followSymlinks = false,\n includeDirs: includeDirectories = true,\n includeFiles = true,\n includeSymlinks = true,\n match,\n maxDepth = Number.POSITIVE_INFINITY,\n skip\n} = {}) {\n assertValidFileOrDirectoryPath(directory);\n if (maxDepth < 0) {\n return;\n }\n const mappedMatch = match ? match.map((pattern) => typeof pattern === \"string\" ? globToRegExp(pattern) : pattern) : undefined;\n const mappedSkip = skip ? skip.map((pattern) => typeof pattern === \"string\" ? globToRegExp(pattern) : pattern) : undefined;\n directory = resolve(toPath(directory));\n if (includeDirectories && walkInclude(directory, extensions, mappedMatch, mappedSkip)) {\n yield await _createWalkEntry(directory);\n }\n if (maxDepth < 1 || !walkInclude(directory, undefined, undefined, mappedSkip)) {\n return;\n }\n try {\n for await (const entry of await readdir(directory, {\n withFileTypes: true\n })) {\n let path = join(directory, entry.name);\n if (entry.isSymbolicLink()) {\n if (followSymlinks) {\n path = await realpath(path);\n } else if (includeSymlinks && walkInclude(path, extensions, mappedMatch, mappedSkip)) {\n yield {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: entry.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: entry.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: entry.isSymbolicLink,\n name: entry.name,\n path\n };\n } else {\n continue;\n }\n }\n if (entry.isSymbolicLink() || entry.isDirectory()) {\n yield* walk(path, {\n extensions,\n followSymlinks,\n includeDirs: includeDirectories,\n includeFiles,\n includeSymlinks,\n match: mappedMatch,\n maxDepth: maxDepth - 1,\n skip: mappedSkip\n });\n } else if (entry.isFile() && includeFiles && walkInclude(path, extensions, mappedMatch, mappedSkip)) {\n yield {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isDirectory: entry.isDirectory,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isFile: entry.isFile,\n // eslint-disable-next-line @typescript-eslint/unbound-method\n isSymbolicLink: entry.isSymbolicLink,\n name: entry.name,\n path\n };\n }\n }\n } catch (error) {\n if (error instanceof WalkError) {\n throw error;\n }\n throw new WalkError(error, directory);\n }\n}\n__name(walk, \"walk\");\n\nexport { walk as default };\n","import walk from './walk-CNcSYQVq.mjs';\n\nvar __defProp = Object.defineProperty;\nvar __name = (target, value) => __defProp(target, \"name\", { value, configurable: true });\nconst collect = /* @__PURE__ */ __name(async (directory, options = {}) => {\n if (!Array.isArray(options.extensions)) {\n options.extensions = [\"js\", \"mjs\", \"cjs\", \"ts\"];\n }\n const entries = [];\n for await (const entry of walk(directory, options)) {\n entries.push(entry.path);\n }\n return entries;\n}, \"collect\");\n\nexport { collect as default };\n","import { readdirSync, readFileSync } from \"node:fs\";\n\nimport { parse } from \"@visulima/path\";\nimport type { PackageJson } from \"type-fest\";\n\ninterface AppExport {\n [key: string]: any;\n app?: string | { app?: string };\n}\n\nexport const ALLOWED_EXTENSIONS = [\".js\", \".ts\", \".mjs\", \".cjs\"];\n\nexport const getAppWorkingDirectoryPath = (appFilePath: string): string | null => {\n let lastParsedPath = parse(appFilePath);\n\n // Once the following condition returns false it means we traversed the whole file system\n // eslint-disable-next-line no-loops/no-loops\n while (lastParsedPath.base && lastParsedPath.root !== lastParsedPath.dir) {\n const parentDirectionItems = readdirSync(lastParsedPath.dir);\n\n const packageJSON = parentDirectionItems.find((item) => item === \"package.json\");\n\n if (packageJSON) {\n return lastParsedPath.dir;\n }\n\n lastParsedPath = parse(lastParsedPath.dir);\n }\n\n return null;\n};\n\nexport const getFrameworkName = (directory: string): \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null => {\n const packageJSONFilePath = `${directory}/package.json`;\n\n const { dependencies } = JSON.parse(readFileSync(packageJSONFilePath).toString()) as PackageJson;\n\n if (dependencies?.express) {\n return \"express\";\n }\n\n if (dependencies?.koa && (dependencies[\"@koa/router\"] || dependencies[\"koa-router\"])) {\n return \"koa\";\n }\n\n if (dependencies?.next) {\n return \"next\";\n }\n\n if (dependencies?.[\"@hapi/hapi\"]) {\n return \"hapi\";\n }\n\n if (dependencies?.fastify) {\n return \"fastify\";\n }\n\n return null;\n};\n\nexport const getApp = (appExport: AppExport, frameworkName: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null): AppExport | string | null => {\n const isExportEmpty = Object.keys(appExport).length === 0;\n\n if (isExportEmpty) {\n return null;\n }\n\n if (frameworkName === \"hapi\") {\n if (typeof (appExport.app as { app?: string }).app === \"string\") {\n return appExport.app as { app: string };\n }\n\n return appExport;\n }\n\n return appExport.app ?? appExport;\n};\n","import type { Server } from \"@hapi/hapi\";\nimport type { Express } from \"express\";\nimport type { FastifyInstance } from \"fastify\";\nimport type Koa from \"koa\";\n\nimport expressRoutes from \"./routes/express-routes\";\nimport fastifyRoutes from \"./routes/fastify-routes\";\nimport hapiRoutes from \"./routes/hapi-routes\";\nimport koaRoutes from \"./routes/koa-routes\";\nimport apiRouteFileParser from \"./routes/next/api-route-file-parser\";\nimport collectApiRouteFiles from \"./routes/next/collect-api-route-files\";\nimport type { Route } from \"./routes/types\";\n\nexport type FrameworkName = \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | \"unknown\";\nexport const getRoutes = async (\n appOrPath: Express | FastifyInstance | Koa | Server | string,\n frameworkName: FrameworkName,\n verbose: boolean,\n): Promise<Route[] | null> => {\n if (frameworkName === \"express\") {\n return expressRoutes(appOrPath as Express);\n }\n\n if (frameworkName === \"koa\") {\n return koaRoutes(appOrPath as Koa);\n }\n\n if (frameworkName === \"hapi\") {\n return hapiRoutes(appOrPath as Server);\n }\n\n if (frameworkName === \"fastify\") {\n return fastifyRoutes(appOrPath as FastifyInstance);\n }\n\n if (frameworkName === \"next\") {\n const apiRouteFiles = await collectApiRouteFiles(appOrPath as string);\n\n if (apiRouteFiles.length === 0) {\n throw new Error(`No API routes found, in \"${appOrPath}\".`);\n }\n\n return apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, appOrPath as string, verbose));\n }\n\n return null;\n};\n","import type { Route } from \"./types\";\n\nconst routesGroupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map<string, Route[]>();\n\n list.forEach((item) => {\n const key = keyGetter(item);\n const collection = map.get(key);\n\n if (collection) {\n collection.push(item);\n } else {\n map.set(key, [item]);\n }\n });\n\n return map;\n};\n\nexport default routesGroupBy;\n","import chalk from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n ANY: chalk.redBright,\n DELETE: chalk.redBright,\n GET: chalk.blue,\n HEAD: chalk.hex(\"#6C7280\"),\n OPTIONS: chalk.hex(\"#6C7280\"),\n PATCH: chalk.yellow,\n POST: chalk.yellow,\n PUT: chalk.yellow,\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${chalk.blue(\"GET\")}${chalk.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${chalk.grey(\"|HEAD\")}` : coloredMethod;\n }\n\n const spacesCount = method === \"GET\" ? 6 : 14 - method.length;\n const spaces = Array.from({ length: spacesCount }).fill(\" \").join(\"\");\n\n const dotsCount = process.stdout.columns - 16 - routePath.length - 4;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\".\").join(\"\") : \"\";\n\n const routeText = routePath\n .split(\"/\")\n .map((segment) => {\n const isDynamicSegment = [\":\", \"[\"].includes(segment[0] ?? \"\");\n\n return isDynamicSegment ? chalk.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${chalk.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[] } = {}): (string | undefined)[] =>\n routesMap\n .map((route) => {\n if (Array.isArray(options.methods) && options.methods.includes(route.method)) {\n return;\n }\n\n if (route.method === \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\") {\n // eslint-disable-next-line no-param-reassign\n route.method = \"ANY\";\n }\n\n // eslint-disable-next-line consistent-return\n return renderRoute(route.method, route.path.replace(\"/pages\", \"\"));\n })\n .filter(Boolean);\n\nexport default routesRender;\n","import { execSync } from \"node:child_process\";\nimport { existsSync, rmSync, statSync } from \"node:fs\";\nimport process from \"node:process\";\n\nimport { extname, join } from \"@visulima/path\";\nimport chalk from \"chalk\";\n\nimport { getRoutes } from \"./get-routes\";\nimport routesGroupBy from \"./routes/routes-group-by\";\nimport routesRender from \"./routes/routes-render\";\nimport type { Route } from \"./routes/types\";\nimport { ALLOWED_EXTENSIONS, getApp, getAppWorkingDirectoryPath, getFrameworkName } from \"./utils\";\n\ninterface RenderOptions {\n excludePaths: string[];\n group: string;\n includePaths: string[];\n methods: string[];\n verbose: boolean;\n}\n\nconst listCommand = async (\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | undefined,\n path: string,\n options: Partial<RenderOptions> = {},\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Promise<void> => {\n const frameworkPath = join(process.cwd(), path);\n\n if (!existsSync(frameworkPath)) {\n throw new Error(\"No such file, invalid path provided.\");\n }\n\n const appWorkingDirectoryPath = getAppWorkingDirectoryPath(frameworkPath);\n\n if (!appWorkingDirectoryPath) {\n throw new Error(\"Please initialize local package.json.\");\n }\n\n if (framework === undefined) {\n const frameworkName = getFrameworkName(appWorkingDirectoryPath);\n\n if (!frameworkName) {\n throw new Error(\"Couldn't detect supported back-end framework.\");\n }\n\n // eslint-disable-next-line no-param-reassign\n framework = frameworkName;\n }\n\n let routes: Route[] | null = null;\n\n if (framework === \"next\") {\n routes = await getRoutes(frameworkPath, \"next\", options.verbose ?? false);\n } else {\n if (!statSync(frameworkPath).isFile()) {\n throw new Error(`${frameworkPath} is directory, but file expected.`);\n }\n\n if (!ALLOWED_EXTENSIONS.includes(extname(frameworkPath))) {\n throw new Error(\"Please specify application .ts/.js/.mjs/.cjs file.\");\n }\n\n const environmentFilePath = `${appWorkingDirectoryPath}/.env`;\n\n if (existsSync(environmentFilePath)) {\n // Loads environment vars in the current process so application\n // that depends on them can be loaded properly below\n const dotEnvironmentFilePath = `${appWorkingDirectoryPath}/node_modules/dotenv/lib/main.js`;\n const dotenv = await import(dotEnvironmentFilePath);\n\n dotenv.config({ path: environmentFilePath });\n }\n\n const isTypeScriptApp = extname(frameworkPath) === \".ts\";\n const tscPath = join(appWorkingDirectoryPath, \"node_modules/.bin/tsc\");\n\n if (isTypeScriptApp && !existsSync(tscPath)) {\n throw new Error(`Please install typescript in ${appWorkingDirectoryPath}`);\n }\n\n try {\n if (isTypeScriptApp) {\n // || rm -r ./framework-list removes framework-list directory in case tsc fails\n\n try {\n execSync(`${tscPath} --outDir framework-list >&2`, { cwd: appWorkingDirectoryPath });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log(\"TSC compilation failed. Please resolve issues in your project.\\n\");\n // eslint-disable-next-line no-console\n console.log(error);\n\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n\n const appJsFilePath = isTypeScriptApp\n ? join(appWorkingDirectoryPath, \"framework-list\", frameworkPath.replace(appWorkingDirectoryPath, \"\").replace(\".ts\", \".js\"))\n : frameworkPath;\n\n const { default: defaultExport } = await import(appJsFilePath);\n\n routes = await getRoutes(\n [\"AsyncFunction\", \"Function\"].includes(defaultExport.constructor.name as string) ? await defaultExport() : getApp(defaultExport, framework),\n framework,\n options.verbose ?? false,\n );\n } finally {\n if (isTypeScriptApp) {\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n }\n\n if (routes === null) {\n throw new Error(`Framework \"${framework}\" is not supported.`);\n }\n\n if (Array.isArray(options.includePaths) && options.includePaths.length > 0) {\n routes = options.includePaths.flatMap((ipath) => (routes as Route[]).filter((route) => route.path.startsWith(ipath)));\n }\n\n if (Array.isArray(options.excludePaths) && options.excludePaths.length > 0) {\n routes = options.excludePaths.flatMap((epath) => (routes as Route[]).filter((route) => !route.path.startsWith(epath)));\n }\n\n if (typeof options.group === \"string\" && options.group !== \"\") {\n // eslint-disable-next-line no-console\n console.log();\n\n const groupedMap = routesGroupBy(routes, (route) => {\n if (options.group === \"path\") {\n return route.path.replace(\"/pages\", \"\").split(\"/\")[1];\n }\n\n return route.tags[0] ?? \"unsorted\";\n });\n\n let counter = 0;\n\n groupedMap.forEach((groupedRoutes, key) => {\n if (counter > 0) {\n // eslint-disable-next-line no-console\n console.log();\n }\n\n const dotsCount = (process.stdout.columns - 16 - key.length) / 2;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\" \").join(\"\") : \"\";\n\n // eslint-disable-next-line no-console\n console.log(dots + chalk.bold.underline(key));\n\n routesRender(groupedRoutes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n } else {\n // eslint-disable-next-line no-console\n console.log();\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n }\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${chalk.greenBright(String(routes.length))} HTTP ${routes.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSAMQ6B5Z_js=require('../../../chunk-SAMQ6B5Z.js');require('../../../chunk-4C666HHU.js');var process=require('process');var i=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await chunkSAMQ6B5Z_js.a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),process.exit(1);}});},m=i;exports.listCommand=m;//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunk3GRHE4LD_js=require('../../../chunk-3GRHE4LD.js');require('../../../chunk-4C666HHU.js');var process=require('process');var i=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await chunk3GRHE4LD_js.a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),process.exit(1);}});},m=i;exports.listCommand=m;//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- import {a}from'../../../chunk-QNRGXATL.mjs';import'../../../chunk-HZWWJL43.mjs';import {exit}from'node:process';var m=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),exit(1);}});},l=m;export{l as listCommand};//# sourceMappingURL=index.mjs.map
1
+ import {a}from'../../../chunk-MDDP5HI3.mjs';import'../../../chunk-HZWWJL43.mjs';import {exit}from'node:process';var m=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),exit(1);}});},l=m;export{l as listCommand};//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSAMQ6B5Z_js=require('../../chunk-SAMQ6B5Z.js');require('../../chunk-4C666HHU.js');Object.defineProperty(exports,"listCommand",{enumerable:true,get:function(){return chunkSAMQ6B5Z_js.a}});//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunk3GRHE4LD_js=require('../../chunk-3GRHE4LD.js');require('../../chunk-4C666HHU.js');Object.defineProperty(exports,"listCommand",{enumerable:true,get:function(){return chunk3GRHE4LD_js.a}});//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- export{a as listCommand}from'../../chunk-QNRGXATL.mjs';import'../../chunk-HZWWJL43.mjs';//# sourceMappingURL=index.mjs.map
1
+ export{a as listCommand}from'../../chunk-MDDP5HI3.mjs';import'../../chunk-HZWWJL43.mjs';//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -31,7 +31,7 @@ type Serializers = {
31
31
  serializer: Serializer;
32
32
  }[];
33
33
 
34
- declare const serialize: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(serializers: Serializers, request: Request, response: Response, data: unknown, options: {
34
+ declare const serialize: <Request extends IncomingMessage, Response extends ServerResponse>(serializers: Serializers, request: Request, response: Response, data: unknown, options: {
35
35
  defaultContentType: string;
36
36
  }) => Buffer | Uint8Array | string;
37
37
 
@@ -39,10 +39,10 @@ declare const xmlTransformer: Serializer;
39
39
 
40
40
  declare const yamlTransformer: Serializer;
41
41
 
42
- declare const createNodeRouter: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>, Schema extends AnyZodObject = ZodObject<{
43
- body?: AnyZodObject | undefined;
44
- headers?: AnyZodObject | undefined;
45
- query?: AnyZodObject | undefined;
42
+ declare const createNodeRouter: <Request extends IncomingMessage, Response extends ServerResponse, Schema extends AnyZodObject = ZodObject<{
43
+ body?: AnyZodObject;
44
+ headers?: AnyZodObject;
45
+ query?: AnyZodObject;
46
46
  }, zod.UnknownKeysParam, zod.ZodTypeAny, {
47
47
  body?: unknown;
48
48
  headers?: unknown;
@@ -66,10 +66,10 @@ declare const createNodeRouter: <Request extends IncomingMessage, Response exten
66
66
  showTrace?: boolean;
67
67
  }) => NodeRouter<Request, Response, Schema>;
68
68
 
69
- declare const onError: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(errorHandlers: ErrorHandlers, showTrace: boolean) => (error: unknown, request: Request, response: Response) => Promise<void>;
69
+ declare const onError: <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => (error: unknown, request: Request, response: Response) => Promise<void>;
70
70
  declare const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response, routes: Route<Nextable<FunctionLike>>[]) => ValueOrPromise<void>;
71
71
 
72
- declare const corsMiddleware: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(options?: CorsOptions | CorsOptionsDelegate) => _visulima_connect.Nextable<_visulima_connect.NodeRequestHandler<Request, Response>>;
72
+ declare const corsMiddleware: <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => _visulima_connect.Nextable<_visulima_connect.NodeRequestHandler<Request, Response>>;
73
73
 
74
74
  declare const httpHeaderNormalizerMiddleware: (options_?: {
75
75
  canonical?: boolean;
@@ -77,8 +77,8 @@ declare const httpHeaderNormalizerMiddleware: (options_?: {
77
77
  }) => ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>);
78
78
 
79
79
  type HeaderValue = ReadonlyArray<string> | number | string;
80
- declare const rateLimiterMiddleware: (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) => <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<void>;
80
+ declare const rateLimiterMiddleware: (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) => <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<void>;
81
81
 
82
- declare const serializersMiddleware: (serializers?: Serializers, defaultContentType?: string) => <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<ValueOrPromise<void>>;
82
+ declare const serializersMiddleware: (serializers?: Serializers, defaultContentType?: string) => <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<ValueOrPromise<void>>;
83
83
 
84
84
  export { type Serializer, type Serializers, corsMiddleware, createNodeRouter, httpHeaderNormalizerMiddleware, onError, onNoMatch, rateLimiterMiddleware, serialize, serializersMiddleware, xmlTransformer, yamlTransformer };
@@ -31,7 +31,7 @@ type Serializers = {
31
31
  serializer: Serializer;
32
32
  }[];
33
33
 
34
- declare const serialize: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(serializers: Serializers, request: Request, response: Response, data: unknown, options: {
34
+ declare const serialize: <Request extends IncomingMessage, Response extends ServerResponse>(serializers: Serializers, request: Request, response: Response, data: unknown, options: {
35
35
  defaultContentType: string;
36
36
  }) => Buffer | Uint8Array | string;
37
37
 
@@ -39,10 +39,10 @@ declare const xmlTransformer: Serializer;
39
39
 
40
40
  declare const yamlTransformer: Serializer;
41
41
 
42
- declare const createNodeRouter: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>, Schema extends AnyZodObject = ZodObject<{
43
- body?: AnyZodObject | undefined;
44
- headers?: AnyZodObject | undefined;
45
- query?: AnyZodObject | undefined;
42
+ declare const createNodeRouter: <Request extends IncomingMessage, Response extends ServerResponse, Schema extends AnyZodObject = ZodObject<{
43
+ body?: AnyZodObject;
44
+ headers?: AnyZodObject;
45
+ query?: AnyZodObject;
46
46
  }, zod.UnknownKeysParam, zod.ZodTypeAny, {
47
47
  body?: unknown;
48
48
  headers?: unknown;
@@ -66,10 +66,10 @@ declare const createNodeRouter: <Request extends IncomingMessage, Response exten
66
66
  showTrace?: boolean;
67
67
  }) => NodeRouter<Request, Response, Schema>;
68
68
 
69
- declare const onError: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(errorHandlers: ErrorHandlers, showTrace: boolean) => (error: unknown, request: Request, response: Response) => Promise<void>;
69
+ declare const onError: <Request extends IncomingMessage, Response extends ServerResponse>(errorHandlers: ErrorHandlers, showTrace: boolean) => (error: unknown, request: Request, response: Response) => Promise<void>;
70
70
  declare const onNoMatch: <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response, routes: Route<Nextable<FunctionLike>>[]) => ValueOrPromise<void>;
71
71
 
72
- declare const corsMiddleware: <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(options?: CorsOptions | CorsOptionsDelegate) => _visulima_connect.Nextable<_visulima_connect.NodeRequestHandler<Request, Response>>;
72
+ declare const corsMiddleware: <Request extends IncomingMessage, Response extends ServerResponse>(options?: CorsOptions | CorsOptionsDelegate) => _visulima_connect.Nextable<_visulima_connect.NodeRequestHandler<Request, Response>>;
73
73
 
74
74
  declare const httpHeaderNormalizerMiddleware: (options_?: {
75
75
  canonical?: boolean;
@@ -77,8 +77,8 @@ declare const httpHeaderNormalizerMiddleware: (options_?: {
77
77
  }) => ((request: IncomingMessage, response: ServerResponse, next: NextHandler) => ValueOrPromise<void>);
78
78
 
79
79
  type HeaderValue = ReadonlyArray<string> | number | string;
80
- declare const rateLimiterMiddleware: (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) => <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<void>;
80
+ declare const rateLimiterMiddleware: (rateLimiter: RateLimiterAbstract, headers?: (limiterResponse: RateLimiterRes) => Record<string, HeaderValue>) => <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<void>;
81
81
 
82
- declare const serializersMiddleware: (serializers?: Serializers, defaultContentType?: string) => <Request extends IncomingMessage, Response extends ServerResponse<IncomingMessage>>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<ValueOrPromise<void>>;
82
+ declare const serializersMiddleware: (serializers?: Serializers, defaultContentType?: string) => <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: NextApiResponse | Response, next: NextHandler) => Promise<ValueOrPromise<void>>;
83
83
 
84
84
  export { type Serializer, type Serializers, corsMiddleware, createNodeRouter, httpHeaderNormalizerMiddleware, onError, onNoMatch, rateLimiterMiddleware, serialize, serializersMiddleware, xmlTransformer, yamlTransformer };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/api-platform",
3
- "version": "3.0.31",
3
+ "version": "3.0.33",
4
4
  "description": "Visulima API platform is a set of tools to build and consume web APIs",
5
5
  "keywords": [
6
6
  "anolilab",
@@ -125,9 +125,9 @@
125
125
  "LICENSE.md"
126
126
  ],
127
127
  "dependencies": {
128
- "@visulima/connect": "3.0.16",
129
- "@visulima/jsdoc-open-api": "2.0.69",
130
- "@visulima/path": "1.3.1",
128
+ "@visulima/connect": "3.0.17",
129
+ "@visulima/jsdoc-open-api": "2.0.71",
130
+ "@visulima/path": "1.3.3",
131
131
  "accepts": "^1.3.8",
132
132
  "debug": "^4.4.0",
133
133
  "http-errors": "^2.0.0",
@@ -136,7 +136,7 @@
136
136
  "lodash.merge": "^4.6.2",
137
137
  "schema-dts": "^1.1.2",
138
138
  "ts-japi": "^1.11.4",
139
- "yaml": "^2.6.1",
139
+ "yaml": "^2.7.0",
140
140
  "zod-to-ts": "^1.2.0"
141
141
  },
142
142
  "devDependencies": {
@@ -154,8 +154,8 @@
154
154
  "@types/accepts": "^1.3.7",
155
155
  "@types/cors": "^2.8.17",
156
156
  "@types/debug": "^4.1.12",
157
- "@types/express": "4.17.21",
158
- "@types/express-serve-static-core": "4.19.6",
157
+ "@types/express": "5.0.0",
158
+ "@types/express-serve-static-core": "5.0.4",
159
159
  "@types/http-errors": "^2.0.4",
160
160
  "@types/jstoxml": "^2.0.4",
161
161
  "@types/koa": "^2.15.0",
@@ -167,14 +167,14 @@
167
167
  "@types/react-dom": "^18.3.1",
168
168
  "@types/swagger-ui-react": "^4.18.3",
169
169
  "@types/webpack": "^5.28.5",
170
- "@visulima/crud": "2.0.33",
171
- "@visulima/fs": "2.3.5",
170
+ "@visulima/crud": "2.0.34",
171
+ "@visulima/fs": "2.3.7",
172
172
  "@vitest/coverage-v8": "^2.1.8",
173
173
  "@vitest/ui": "^2.1.8",
174
- "chalk": "5.3.0",
175
- "commander": "^12.1.0",
174
+ "chalk": "5.4.1",
175
+ "commander": "^13.0.0",
176
176
  "conventional-changelog-conventionalcommits": "8.0.0",
177
- "core-js": "^3.39.0",
177
+ "core-js": "^3.40.0",
178
178
  "cors": "^2.8.5",
179
179
  "cross-env": "^7.0.3",
180
180
  "eslint": "8.57.0",
@@ -183,8 +183,8 @@
183
183
  "eslint-plugin-import": "npm:eslint-plugin-i@^2.29.1",
184
184
  "eslint-plugin-jsx-a11y": "^6.10.2",
185
185
  "eslint-plugin-mdx": "^3.1.5",
186
- "eslint-plugin-react": "7.34.3",
187
- "eslint-plugin-react-hooks": "4.6.2",
186
+ "eslint-plugin-react": "7.37.3",
187
+ "eslint-plugin-react-hooks": "5.1.0",
188
188
  "eslint-plugin-ssr-friendly": "^1.3.0",
189
189
  "eslint-plugin-testing-library": "^7.1.1",
190
190
  "eslint-plugin-validate-jsx-nesting": "^0.1.1",
@@ -192,10 +192,10 @@
192
192
  "eslint-plugin-vitest-globals": "^1.5.0",
193
193
  "eslint-plugin-zod": "^1.4.0",
194
194
  "express": "^4.21.2",
195
- "fastify": "^5.2.0",
195
+ "fastify": "^5.2.1",
196
196
  "koa": "^2.15.3",
197
197
  "mobx": "^6.13.5",
198
- "next": "^14.2.4",
198
+ "next": "^15.1.4",
199
199
  "next-test-api-route-handler": "^4.0.14",
200
200
  "node-mocks-http": "^1.16.2",
201
201
  "openapi-types": "^12.1.3",
@@ -204,15 +204,15 @@
204
204
  "react": "^19.0.0",
205
205
  "react-dom": "^19.0.0",
206
206
  "redoc": "^2.2.0",
207
- "rimraf": "5.0.9",
208
- "secretlint": "8.2.4",
209
- "semantic-release": "24.0.0",
210
- "styled-components": "^6.1.13",
211
- "swagger-ui-dist": "^5.17.14",
212
- "swagger-ui-react": "^5.17.14",
207
+ "rimraf": "6.0.1",
208
+ "secretlint": "9.0.0",
209
+ "semantic-release": "24.2.1",
210
+ "styled-components": "^6.1.14",
211
+ "swagger-ui-dist": "^5.18.2",
212
+ "swagger-ui-react": "^5.18.2",
213
213
  "tsup": "^8.3.5",
214
- "type-fest": "^4.31.0",
215
- "typescript": "5.4.5",
214
+ "type-fest": "^4.32.0",
215
+ "typescript": "5.7.3",
216
216
  "vitest": "^2.1.8",
217
217
  "webpack": "^5.97.1",
218
218
  "zod": "^3.24.1"
@@ -220,7 +220,7 @@
220
220
  "peerDependencies": {
221
221
  "@hapi/hapi": "^21.3.9",
222
222
  "@koa/router": "^12.0.1",
223
- "@visulima/crud": "2.0.33",
223
+ "@visulima/crud": "2.0.34",
224
224
  "@visulima/readdir": "2.0.12",
225
225
  "chalk": "5.3.0",
226
226
  "commander": "^12.0.0",
@@ -1,6 +0,0 @@
1
- import {execSync}from'node:child_process';import {existsSync,statSync,rmSync,readdirSync,readFileSync}from'node:fs';import se,{cwd}from'node:process';import {normalize,basename,resolve,join,extname,parse,toNamespacedPath}from'@visulima/path';import h from'chalk';import {parseFile,jsDocumentCommentsToOpenApi,swaggerJsDocumentCommentsToOpenApi}from'@visulima/jsdoc-open-api';import {stat,readdir,realpath}from'node:fs/promises';import {toPath}from'@visulima/path/utils';var ie=(e,t)=>{if(t.length===0)throw new Error("must include at least one key to map");let r=e.toString();return t.forEach(o=>{r=o.optional?r.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):r.replace("(?:([^\\/]+?))",`:${o.name}`);}),r.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/gu,"/")},F=ie;var pe=(e,t)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let r="";t.length>0&&(r=F(e,t));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//u.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/gu,"$1").slice(1):r?r.slice(1):e.toString()},j=pe;var ce=(e,t,r)=>{let o=e.route.stack.at(-1),s=t.map(i=>({in:"path",name:i.name,required:!i.optional})),a=e.route.stack.filter(i=>i.handle.metadata);if(a.length>1)throw new Error("Only one metadata middleware is allowed per route");let c=(r+e.route.path).replaceAll(/\/{2,}/gu,"/");return a.length===0?{method:o.method,path:c,pathParams:s}:{metadata:a[0].handle.metadata,method:o.method,path:c,pathParams:s}},L=(e,t,r,o)=>{if(o=[...o,...r.keys],r.name==="router"&&r.handle&&r.handle.stack!==void 0)for(let s of r.handle.stack)t=t||"",L(e,`${t}/${j(r.regexp,r.keys)}`,s,o);!r.route||r.route.stack.length===0||e.push(ce(r,o,t));},le=e=>{let t=e._router||e.router,r=[];for(let o of t.stack)L(r,"",o,[]);return r},$=le;var me=e=>{let t=[];return $(e).forEach(r=>{t.push({file:"unknown",method:r.method.toUpperCase(),path:r.path,tags:[]});}),t},I=me;var C=e=>e.replaceAll(/ \(.*\)/gu,"").trim(),N=e=>e.trim().split(" ")[1].slice(1,-1),fe=e=>{let r=e.printRoutes().replaceAll(/[─│└├]/gu," ").trimEnd().split(`
2
- `),o=r.reduce((a,c,i)=>{let p=C(c);if(C(r[i-1]??"")===p){let R=a.filter(T=>T.index<i&&T.segment===p),{methods:O}=R.at(-1);return O!==null&&O.push(N(c)),a}let l=c.replaceAll(/ \(.*\)/gu,"").match(/ /gu);if(l===null)throw new Error("Invalid spaces");let n=l.length/4,d=c.includes("("),P=d?[N(c)]:null;return a.push({depth:n,index:i,isRoute:d,methods:P,segment:p}),a},[]),s=[];return o.filter(a=>a.isRoute).forEach(a=>{let i=[...o.filter(p=>p.index<a.index&&p.depth<a.depth).filter((p,m,l)=>!l.find(n=>n.depth===p.depth&&n.index>p.index)).map(p=>p.segment),a.segment].join("");if(a.methods===null)throw new Error("Invalid methods");a.methods.forEach(p=>{s.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),s},_=fe;var ue=e=>{let r=e._core.router.routes,o=[];return [...r.keys()].forEach(s=>{r.get(s).routes.forEach(a=>{o.push({file:"unknown",method:a.route.method.toUpperCase(),path:a.path,tags:[]});});}),o},K=ue;var de=e=>{let t=[];return e.middleware.filter(r=>r.router).flatMap(r=>r.router.stack).forEach(r=>{t.push({file:"unknown",method:r.methods.join("|").toUpperCase(),path:r.path,tags:[]});}),t},M=de;var J=/\.(js|ts|mjs|cjs)$/u,xe=(e,t,r=!1)=>{e=toNamespacedPath(e);let o=toNamespacedPath(cwd()),s=[],a=parseFile(e,jsDocumentCommentsToOpenApi,r);s=[...s,...a.map(p=>p.spec)];let c=parseFile(e,swaggerJsDocumentCommentsToOpenApi,r);s=[...s,...c.map(p=>p.spec)];let i=[];return s.length===0?(readFileSync(e,"utf8").split(/\r?\n/u).forEach(m=>{let l=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/u.exec(m);if(l){let[,n]=l;n==="GET"&&(n="GET|HEAD"),i.push({file:e.replace(`${o}/`,""),method:n,path:toNamespacedPath(e.replace(t,"").replace(J,"")),tags:[]});}}),i.length===0&&i.push({file:e.replace(`${o}/`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:toNamespacedPath(e.replace(t,"").replace(J,"")),tags:[]}),i):(s.forEach(p=>{Object.entries(p?.paths??{}).forEach(([l,n])=>{Object.entries(n).forEach(([P,R])=>{i.push({file:e.replace(`${o}/`,""),method:P.toUpperCase(),path:toNamespacedPath(l),tags:R.tags});});});}),i)},U=xe;var Se=Object.defineProperty,we=(e,t)=>Se(e,"name",{value:t,configurable:!0}),Pe=Object.defineProperty,Re=we((e,t)=>Pe(e,"name",{value:t,configurable:!0}),"n"),W=Re(e=>{if(!e||!(e instanceof URL)&&typeof e!="string")throw new TypeError("Path must be a non-empty string or URL.")},"assertValidFileOrDirectoryPath");var ke=Object.defineProperty,G=(e,t)=>ke(e,"name",{value:t,configurable:!0}),ve=Object.defineProperty,be=G((e,t)=>ve(e,"name",{value:t,configurable:!0}),"t"),g=class extends Error{static{G(this,"i");}static{be(this,"WalkError");}root;constructor(t,r){super(`${t instanceof Error?t.message:t} for path "${r}"`),this.cause=t,this.root=r;}get name(){return "WalkError"}set name(t){throw new Error("Cannot overwrite name of WalkError")}};var Ae=Object.defineProperty,B=(e,t)=>Ae(e,"name",{value:t,configurable:!0}),De=Object.defineProperty,Oe=B((e,t)=>De(e,"name",{value:t,configurable:!0}),"r"),k=Oe(e=>{let t=e.replace(/\.\*/g,".([^/]*)").replace(/\*\*/g,"(.*)").replace(/(?<!\.)\*(?!\*)/g,"([^/]*)").replace(/\?/g,"[^/]").replace(/\.(?!\*)/g,"\\.").replace(/\{/g,"(").replace(/\}/g,")").replace(/,/g,"|").replace(/\[!(.*?)\]/g,"[^$1]");return new RegExp(`^${t}$`)},"globToRegExp"),Te=Object.defineProperty,Fe=B((e,t)=>Te(e,"name",{value:t,configurable:!0}),"n"),E=Fe((e,t,r,o)=>Array.isArray(t)&&t.length>0&&!t.some(s=>e.endsWith(s))||r&&!r.some(s=>s.test(e))?!1:!o?.some(s=>s.test(e)),"walkInclude");var je=Object.defineProperty,Y=(e,t)=>je(e,"name",{value:t,configurable:!0}),He=Object.defineProperty,X=Y((e,t)=>He(e,"name",{value:t,configurable:!0}),"f"),Je=X(async e=>{let t=normalize(e),r=basename(t),o=await stat(t);return {isDirectory:o.isDirectory,isFile:o.isFile,isSymbolicLink:o.isSymbolicLink,name:r,path:t}},"_createWalkEntry");async function*x(e,{extensions:t,followSymlinks:r=!1,includeDirs:o=!0,includeFiles:s=!0,includeSymlinks:a=!0,match:c,maxDepth:i=Number.POSITIVE_INFINITY,skip:p}={}){if(W(e),i<0)return;let m=c?c.map(n=>typeof n=="string"?k(n):n):void 0,l=p?p.map(n=>typeof n=="string"?k(n):n):void 0;if(e=resolve(toPath(e)),o&&E(e,t,m,l)&&(yield await Je(e)),!(i<1||!E(e,void 0,void 0,l)))try{for await(let n of await readdir(e,{withFileTypes:!0})){let d=join(e,n.name);if(n.isSymbolicLink())if(r)d=await realpath(d);else if(a&&E(d,t,m,l))yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d};else continue;n.isSymbolicLink()||n.isDirectory()?yield*x(d,{extensions:t,followSymlinks:r,includeDirs:o,includeFiles:s,includeSymlinks:a,match:m,maxDepth:i-1,skip:l}):n.isFile()&&s&&E(d,t,m,l)&&(yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:d});}}catch(n){throw n instanceof g?n:new g(n,e)}}Y(x,"d");X(x,"walk");var Ue=Object.defineProperty,We=(e,t)=>Ue(e,"name",{value:t,configurable:!0}),Ge=Object.defineProperty,Be=We((e,t)=>Ge(e,"name",{value:t,configurable:!0}),"e"),v=Be(async(e,t={})=>{Array.isArray(t.extensions)||(t.extensions=["js","mjs","cjs","ts"]);let r=[];for await(let o of x(e,t))r.push(o.path);return r},"collect");var w=[".js",".ts",".mjs",".cjs"],V=e=>{let t=parse(e);for(;t.base&&t.root!==t.dir;){if(readdirSync(t.dir).find(s=>s==="package.json"))return t.dir;t=parse(t.dir);}return null},z=e=>{let t=`${e}/package.json`,{dependencies:r}=JSON.parse(readFileSync(t).toString());return r?.express?"express":r?.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r?.next?"next":r?.["@hapi/hapi"]?"hapi":r?.fastify?"fastify":null},Q=(e,t)=>Object.keys(e).length===0?null:t==="hapi"?typeof e.app.app=="string"?e.app:e:e.app??e;var ee=e=>{try{return statSync(e).isDirectory()}catch{return !1}},Ve=async(e="")=>{let t=join(e,"pages/api");return !ee(t)&&(t=join(e,"src/pages/api"),!ee(t))?[]:v(t,{extensions:w,includeDirs:!1})},te=Ve;var b=async(e,t,r)=>{if(t==="express")return I(e);if(t==="koa")return M(e);if(t==="hapi")return K(e);if(t==="fastify")return _(e);if(t==="next"){let o=await te(e);if(o.length===0)throw new Error(`No API routes found, in "${e}".`);return o.flatMap(s=>U(s,e,r))}return null};var ze=(e,t)=>{let r=new Map;return e.forEach(o=>{let s=t(o),a=r.get(s);a?a.push(o):r.set(s,[o]);}),r},re=ze;var Qe=(e,t)=>{let r={ANY:h.redBright,DELETE:h.redBright,GET:h.blue,HEAD:h.hex("#6C7280"),OPTIONS:h.hex("#6C7280"),PATCH:h.yellow,POST:h.yellow,PUT:h.yellow},o;if(e==="GET|HEAD")o=`${h.blue("GET")}${h.grey("|HEAD")}`;else {let m=r[e](e);o=e==="GET"?`${m}${h.grey("|HEAD")}`:m;}let s=e==="GET"?6:14-e.length,a=Array.from({length:s}).fill(" ").join(""),c=process.stdout.columns-16-t.length-4,i=c>0?Array.from({length:c}).fill(".").join(""):"",p=t.split("/").map(m=>[":","["].includes(m[0]??"")?h.yellowBright(m):m).join("/");return ` ${o}${a}${p}${h.grey(i)}`},Ze=(e,t={})=>e.map(r=>{if(!(Array.isArray(t.methods)&&t.methods.includes(r.method)))return r.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(r.method="ANY"),Qe(r.method,r.path.replace("/pages",""))}).filter(Boolean),A=Ze;var rt=async(e,t,r={})=>{let o=join(se.cwd(),t);if(!existsSync(o))throw new Error("No such file, invalid path provided.");let s=V(o);if(!s)throw new Error("Please initialize local package.json.");if(e===void 0){let c=z(s);if(!c)throw new Error("Couldn't detect supported back-end framework.");e=c;}let a=null;if(e==="next")a=await b(o,"next",r.verbose??!1);else {if(!statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!w.includes(extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let c=`${s}/.env`;existsSync(c)&&(await import(`${s}/node_modules/dotenv/lib/main.js`)).config({path:c});let i=extname(o)===".ts",p=join(s,"node_modules/.bin/tsc");if(i&&!existsSync(p))throw new Error(`Please install typescript in ${s}`);try{if(i)try{execSync(`${p} --outDir framework-list >&2`,{cwd:s});}catch(n){console.log(`TSC compilation failed. Please resolve issues in your project.
3
- `),console.log(n),rmSync(join(s,"framework-list"),{recursive:!0});}let m=i?join(s,"framework-list",o.replace(s,"").replace(".ts",".js")):o,{default:l}=await import(m);a=await b(["AsyncFunction","Function"].includes(l.constructor.name)?await l():Q(l,e),e,r.verbose??!1);}finally{i&&rmSync(join(s,"framework-list"),{recursive:!0});}}if(a===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(r.includePaths)&&r.includePaths.length>0&&(a=r.includePaths.flatMap(c=>a.filter(i=>i.path.startsWith(c)))),Array.isArray(r.excludePaths)&&r.excludePaths.length>0&&(a=r.excludePaths.flatMap(c=>a.filter(i=>!i.path.startsWith(c)))),typeof r.group=="string"&&r.group!==""){console.log();let c=re(a,p=>r.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;c.forEach((p,m)=>{i>0&&console.log();let l=(se.stdout.columns-16-m.length)/2,n=l>0?Array.from({length:l}).fill(" ").join(""):"";console.log(n+h.bold.underline(m)),A(p,r).forEach(d=>{console.log(d);}),i+=1;});}else console.log(),A(a,r).forEach(c=>{console.log(c);});console.log(`
4
- Listed ${h.greenBright(String(a.length))} HTTP ${a.length===1?"route":"routes"}.
5
- `);},kr=rt;export{kr as a};//# sourceMappingURL=chunk-QNRGXATL.mjs.map
6
- //# sourceMappingURL=chunk-QNRGXATL.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/framework/cli/command/list/routes/express/map-keys-to-path.ts","../src/framework/cli/command/list/routes/express/path-regex-parser.ts","../src/framework/cli/command/list/routes/express/express-path-parser.ts","../src/framework/cli/command/list/routes/express-routes.ts","../src/framework/cli/command/list/routes/fastify-routes.ts","../src/framework/cli/command/list/routes/hapi-routes.ts","../src/framework/cli/command/list/routes/koa-routes.ts","../src/framework/cli/command/list/routes/next/api-route-file-parser.ts","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/assertValidFileOrDirectoryPath-DgPIPmZT.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/WalkError-BsngoIKJ.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/walk-include-B-MbUqMt.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/walk-DH-95i_B.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/collect-CRzGiRGg.mjs","../src/framework/cli/command/list/utils.ts","../src/framework/cli/command/list/routes/next/collect-api-route-files.ts","../src/framework/cli/command/list/get-routes.ts","../src/framework/cli/command/list/routes/routes-group-by.ts","../src/framework/cli/command/list/routes/routes-render.ts","../src/framework/cli/command/list/list-command.ts"],"names":["mapKeysToPath","layerRegexPath","keys","convertedSubPath","key","map_keys_to_path_default","pathRegexParser","mappedPath","match","path_regex_parser_default","parseRouteLayer","layer","basePath","lastRequestHandler","pathParameters","filtered","element","path","traverse","routes","l","expressPathParser","app","router","express_path_parser_default","expressRoutes","route","express_routes_default","getSegment","line","getMethod","fastifyRoutes","lines","segments","allSegments","index","segment","entries","item","methods","spaces","depth","isRoute","seg","_index","previousArray","r","method","fastify_routes_default","hapiRoutes","coreRoutes","hapi_routes_default","koaRoutes","middlewareFunction","koa_routes_default","extensionRegex","apiRouteFileParser","apiRouteFile","cwd","verbose","toNamespacedPath","cwdPath","nodeCwd","specs","parsedJsDocumentFile","parseFile","jsDocumentCommentsToOpenApi","parsedSwaggerJsDocumentFile","swaggerJsDocumentCommentsToOpenApi","readFileSync","spec","pathSpec","methodSpec","api_route_file_parser_default","a","t","n","o","s","c","p","u","v","g","h","O","S","P","x","I","F","b","y","f","m","d","i","w","L","D","e","ALLOWED_EXTENSIONS","getAppWorkingDirectoryPath","appFilePath","lastParsedPath","parse","readdirSync","getFrameworkName","directory","packageJSONFilePath","dependencies","getApp","appExport","frameworkName","isDirectory","statSync","collectApiRouteFiles","apiFolderPath","join","collect_api_route_files_default","getRoutes","appOrPath","apiRouteFiles","routesGroupBy","list","keyGetter","map","collection","routes_group_by_default","renderRoute","routePath","colorMap","chalk","methodText","coloredMethod","spacesCount","dotsCount","dots","routeText","routesRender","routesMap","options","routes_render_default","listCommand","framework","frameworkPath","process","existsSync","appWorkingDirectoryPath","extname","environmentFilePath","isTypeScriptApp","tscPath","execSync","error","rmSync","appJsFilePath","defaultExport","ipath","epath","groupedMap","counter","groupedRoutes","renderedRoute","list_command_default"],"mappings":"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","file":"chunk-QNRGXATL.mjs","sourcesContent":["import type { ExpressRegex, Key } from \"./types\";\n\n/**\n * Map's the keys/path variables to the regex inside a given path\n *\n * @param layerRegexPath The regex for a router with path parameters\n * @param keys The keys that represent the path parameters\n *\n * @returns The regex for a path variable converted to original string on the express route\n */\nconst mapKeysToPath = (layerRegexPath: ExpressRegex, keys: Key[]): string => {\n if (keys.length === 0) {\n throw new Error(\"must include at least one key to map\");\n }\n\n let convertedSubPath = layerRegexPath.toString();\n\n keys.forEach((key) => {\n convertedSubPath = key.optional\n ? convertedSubPath.replace(\"(?:\\\\/([^\\\\/]+?))?\\\\\", `/:${key.name}?`)\n : convertedSubPath.replace(\"(?:([^\\\\/]+?))\", `:${key.name}`);\n });\n\n return convertedSubPath\n .replace(\"/?(?=\\\\/|$)/i\", \"\")\n .replace(\"/^\", \"\")\n .replaceAll(\"\\\\\", \"\")\n .replaceAll(/\\/{2,}/gu, \"/\");\n};\n\nexport default mapKeysToPath;\n","import mapKeysToPath from \"./map-keys-to-path\";\nimport type { ExpressRegex, Key } from \"./types\";\n\n/** Parses an express layer's regex and converts it to the original format seen in code.\n *\n * @param layerRegexPath The layer's regex pattern\n * @param keys The keys that represent the layer's path parameters\n * @returns The path string for that layer\n * Code inspired and modify from:\n * https://github.com/expressjs/express/issues/3308#issuecomment-300957572\n */\nconst pathRegexParser = (layerRegexPath: ExpressRegex | string, keys: Key[]): string => {\n if (typeof layerRegexPath === \"string\") {\n return layerRegexPath;\n }\n\n if (layerRegexPath.fast_slash) {\n return \"\";\n }\n\n if (layerRegexPath.fast_star) {\n return \"*\";\n }\n\n let mappedPath = \"\";\n\n if (keys.length > 0) {\n mappedPath = mapKeysToPath(layerRegexPath, keys);\n }\n\n const match = /^\\/\\^((?:\\\\[$()*+./?[\\\\\\]^{|}]|[^$()*+./?[\\\\\\]^{|}])*)\\$\\//u.exec(\n layerRegexPath.toString().replace(\"\\\\/?\", \"\").replace(\"(?=\\\\/|$)\", \"$\"),\n ) as string[];\n\n if (Array.isArray(match) && match.length > 1) {\n return (match[1] as string).replaceAll(/\\\\(.)/gu, \"$1\").slice(1);\n }\n\n if (mappedPath) {\n return mappedPath.slice(1);\n }\n\n return layerRegexPath.toString();\n};\n\nexport default pathRegexParser;\n","import type { Express, Router } from \"express\";\n\nimport pathRegexParser from \"./path-regex-parser\";\nimport type { Key, Layer, Parameter, Route, RouteMetaData } from \"./types\";\n\n/**\n * Parses a route object. Route objects are the leafs of an express router tree\n *\n * @param layer The layer of this route object - represents the stack of middleware and other metadata\n * @param keys The full set of keys for this particular route\n * @param basePath The base path as it was initial declared for this route\n * @returns A ExpressPath object holding the metadata for a given route\n */\nconst parseRouteLayer = (layer: Required<Layer>, keys: Key[], basePath: string): RouteMetaData => {\n const lastRequestHandler = layer.route.stack.at(-1) as Layer;\n const pathParameters: Parameter[] = keys.map((key) => {\n return { in: \"path\", name: key.name, required: !key.optional };\n });\n\n const filtered = layer.route.stack.filter((element) => (element.handle as Route).metadata);\n\n if (filtered.length > 1) {\n throw new Error(\"Only one metadata middleware is allowed per route\");\n }\n\n const path = (basePath + layer.route.path).replaceAll(/\\/{2,}/gu, \"/\");\n\n if (filtered.length === 0) {\n return { method: lastRequestHandler.method, path, pathParams: pathParameters };\n }\n\n return {\n metadata: ((filtered[0] as Layer).handle as Route).metadata,\n method: lastRequestHandler.method,\n path,\n pathParams: pathParameters,\n };\n};\n\n/**\n * Recursive traversal method for the express router and middleware tree.\n *\n * @param routes The array of routes to add to\n * @param path The current path segment that we have traversed so far\n * @param layer The current 'layer' of the router tree\n * @param keys The keys for the parameter's in the current path branch of the traversal\n * @returns void - base case saves result to internal object\n */\nconst traverse = (routes: RouteMetaData[], path: string, layer: Layer, keys: Key[]): void => {\n // eslint-disable-next-line no-param-reassign\n keys = [...keys, ...layer.keys];\n\n if (layer.name === \"router\" && layer.handle && layer.handle.stack !== undefined) {\n for (const l of layer.handle.stack) {\n // eslint-disable-next-line no-param-reassign\n path = path || \"\";\n\n traverse(routes, `${path}/${pathRegexParser(layer.regexp, layer.keys)}`, l as Layer, keys);\n }\n }\n\n if (!layer.route || layer.route.stack.length === 0) {\n return;\n }\n\n routes.push(parseRouteLayer(layer as Required<Layer>, keys, path));\n};\n\n// @TODO use this to parse the express swagger\n\n/**\n * Parses an Express app and generates list of routes with metadata.\n *\n * Can Parse:\n * - Nested Routers and Complex Express Projects\n * - Optional parameters e.g. /:name?\n * - Complex Matching routes e.g. /ma*tch, /ex(ab)?mple\n * - Regex routes e.g. /\\/abc|\\/xyz/\n * - Array of paths e.g. app.get(['/abc', '/xyz']) -> /abc,xyz/\n *\n * @param app The Express app reference. Must be used after all routes have been attached\n *\n * @returns List of routes for this express app with meta-data that has been picked up\n */\nconst expressPathParser = (app: Express): RouteMetaData[] => {\n // eslint-disable-next-line no-underscore-dangle\n const router: Router = app._router || app.router;\n const routes: RouteMetaData[] = [];\n\n for (const layer of router.stack) {\n // @TODO: revisit this type assertion\n traverse(routes, \"\", layer as unknown as Layer, []);\n }\n\n return routes;\n};\n\nexport default expressPathParser;\n","import type { Express } from \"express\";\n\nimport expressPathParser from \"./express/express-path-parser\";\nimport type { RouteMetaData } from \"./express/types\";\nimport type { Route } from \"./types\";\n\nconst expressRoutes = (app: Express): Route[] => {\n const routes: Route[] = [];\n\n expressPathParser(app).forEach((route: RouteMetaData) => {\n routes.push({\n file: \"unknown\",\n method: route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default expressRoutes;\n","import type { FastifyInstance } from \"fastify\";\n\nimport type { Route } from \"./types\";\n\n// \"<spaces> activity (GET)\" -> \"activity\"\nconst getSegment = (line: string) => line.replaceAll(/ \\(.*\\)/gu, \"\").trim();\n\n// \"<spaces> activity (GET)\" -> \"GET\"\nconst getMethod = (line: string) => (line.trim().split(\" \")[1] as string).slice(1, -1);\n\ninterface Segment {\n depth: number;\n index: number;\n isRoute: boolean;\n methods: string[] | null;\n segment: string;\n}\n\nconst fastifyRoutes = (app: FastifyInstance): Route[] => {\n const printedRoutes = app\n .printRoutes()\n .replaceAll(/[─│└├]/gu, \" \")\n .trimEnd();\n\n const lines = printedRoutes.split(\"\\n\");\n\n // eslint-disable-next-line unicorn/no-array-reduce\n const segments = lines.reduce((allSegments: Segment[], line, index) => {\n const segment = getSegment(line);\n const previousSegment = getSegment(lines[index - 1] ?? \"\");\n\n if (previousSegment === segment) {\n const entries: Segment[] = allSegments.filter((item) => item.index < index && item.segment === segment);\n\n const { methods } = entries.at(-1) as Segment;\n\n if (methods !== null) {\n methods.push(getMethod(line));\n }\n\n return allSegments;\n }\n\n // spaces preceding segment / not counting single space between segment and (METHOD)\n const spaces = line.replaceAll(/ \\(.*\\)/gu, \"\").match(/ /gu);\n\n if (spaces === null) {\n throw new Error(\"Invalid spaces\");\n }\n\n const depth = spaces.length / 4;\n const isRoute = line.includes(\"(\");\n const methods = isRoute ? [getMethod(line)] : null;\n\n allSegments.push({\n depth,\n index,\n isRoute,\n methods,\n segment,\n });\n\n return allSegments;\n }, []);\n\n const routes: Route[] = [];\n\n segments\n .filter((item) => item.isRoute)\n .forEach((item) => {\n const ancestorSegments = segments\n .filter((seg) => seg.index < item.index && seg.depth < item.depth)\n // eslint-disable-next-line unicorn/prefer-array-some\n .filter((seg, _index, previousArray) => !previousArray.find((segment) => segment.depth === seg.depth && segment.index > seg.index));\n\n const route = [...ancestorSegments.map((r) => r.segment), item.segment].join(\"\");\n\n if (item.methods === null) {\n throw new Error(\"Invalid methods\");\n }\n\n item.methods.forEach((method: string) => {\n routes.push({\n file: \"unknown\",\n method: method.toUpperCase(),\n path: route,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default fastifyRoutes;\n","import type { Server } from \"@hapi/hapi\";\n\nimport type { Route } from \"./types\";\n\nconst hapiRoutes = (app: Server): Route[] => {\n // @ts-expect-error TS2339: Property '_core' does not exist on type 'Server'. Internal API.\n // eslint-disable-next-line no-underscore-dangle\n const core = app._core as any;\n const coreRoutes = core.router.routes;\n const routes: Route[] = [];\n\n [...coreRoutes.keys()].forEach((method: string) => {\n coreRoutes.get(method).routes.forEach((route: any) => {\n routes.push({\n file: \"unknown\",\n method: route.route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default hapiRoutes;\n","import type Koa from \"koa\";\n\nimport type { Route } from \"./types\";\n\nconst koaRoutes = (app: Koa): Route[] => {\n const routes: Route[] = [];\n\n app.middleware\n .filter((middlewareFunction) => (middlewareFunction as any).router)\n\n .flatMap((middlewareFunction) => (middlewareFunction as any).router.stack)\n .forEach((route) => {\n routes.push({\n file: \"unknown\",\n method: route.methods.join(\"|\").toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default koaRoutes;\n","import { readFileSync } from \"node:fs\";\nimport { cwd as nodeCwd } from \"node:process\";\n\nimport type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport { toNamespacedPath } from \"@visulima/path\";\n\nimport type { Route } from \"../types\";\n\n// eslint-disable-next-line regexp/no-unused-capturing-group\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/u;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwd: string, verbose = false): Route[] => {\n // eslint-disable-next-line no-param-reassign\n apiRouteFile = toNamespacedPath(apiRouteFile);\n\n const cwdPath = toNamespacedPath(nodeCwd());\n\n let specs: OpenApiObject[] = [];\n\n const parsedJsDocumentFile = parseFile(apiRouteFile, jsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];\n\n const parsedSwaggerJsDocumentFile = parseFile(apiRouteFile, swaggerJsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];\n\n const routes: Route[] = [];\n\n if (specs.length === 0) {\n const apiRouteFileContent = readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/u).forEach((line) => {\n const match = /[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/u.exec(line);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method as string,\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n\n return routes;\n }\n\n specs.forEach((spec) => {\n const paths = Object.entries(spec?.paths ?? {});\n\n paths.forEach(([path, pathSpec]) => {\n const methods = Object.entries(pathSpec);\n\n methods.forEach(([method, methodSpec]) => {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method.toUpperCase(),\n path: toNamespacedPath(path),\n tags: methodSpec.tags,\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","var a=Object.defineProperty;var t=(e,r)=>a(e,\"name\",{value:r,configurable:!0});var n=Object.defineProperty,o=t((e,r)=>n(e,\"name\",{value:r,configurable:!0}),\"n\");const s=o(e=>{if(!e||!(e instanceof URL)&&typeof e!=\"string\")throw new TypeError(\"Path must be a non-empty string or URL.\")},\"assertValidFileOrDirectoryPath\");export{s as default};\n","var o=Object.defineProperty;var t=(e,r)=>o(e,\"name\",{value:r,configurable:!0});var n=Object.defineProperty,s=t((e,r)=>n(e,\"name\",{value:r,configurable:!0}),\"t\");class c extends Error{static{t(this,\"i\")}static{s(this,\"WalkError\")}root;constructor(r,a){super(`${r instanceof Error?r.message:r} for path \"${a}\"`),this.cause=r,this.root=a}get name(){return\"WalkError\"}set name(r){throw new Error(\"Cannot overwrite name of WalkError\")}}export{c as default};\n","var n=Object.defineProperty;var c=(e,r)=>n(e,\"name\",{value:r,configurable:!0});var p=Object.defineProperty,t=c((e,r)=>p(e,\"name\",{value:r,configurable:!0}),\"r\");const u=t(e=>{const r=e.replace(/\\.\\*/g,\".([^/]*)\").replace(/\\*\\*/g,\"(.*)\").replace(/(?<!\\.)\\*(?!\\*)/g,\"([^/]*)\").replace(/\\?/g,\"[^/]\").replace(/\\.(?!\\*)/g,\"\\\\.\").replace(/\\{/g,\"(\").replace(/\\}/g,\")\").replace(/,/g,\"|\").replace(/\\[!(.*?)\\]/g,\"[^$1]\");return new RegExp(`^${r}$`)},\"globToRegExp\");var o=Object.defineProperty,s=c((e,r)=>o(e,\"name\",{value:r,configurable:!0}),\"n\");const v=s((e,r,g,l)=>Array.isArray(r)&&r.length>0&&!r.some(a=>e.endsWith(a))||g&&!g.some(a=>a.test(e))?!1:!l?.some(a=>a.test(e)),\"walkInclude\");export{v as a,u as c};\n","var h=Object.defineProperty;var c=(e,o)=>h(e,\"name\",{value:o,configurable:!0});import{readdir as w,realpath as D,stat as F}from\"node:fs/promises\";import{resolve as v,join as L,normalize as x,basename as I}from\"@visulima/path\";import{toPath as g}from\"@visulima/path/utils\";import k from\"./WalkError-BsngoIKJ.mjs\";import N from\"./assertValidFileOrDirectoryPath-DgPIPmZT.mjs\";import{c as u,a as l}from\"./walk-include-B-MbUqMt.mjs\";var O=Object.defineProperty,S=c((e,o)=>O(e,\"name\",{value:o,configurable:!0}),\"f\");const P=S(async e=>{const o=x(e),a=I(o),s=await F(o);return{isDirectory:s.isDirectory,isFile:s.isFile,isSymbolicLink:s.isSymbolicLink,name:a,path:o}},\"_createWalkEntry\");async function*b(e,{extensions:o,followSymlinks:a=!1,includeDirs:s=!0,includeFiles:y=!0,includeSymlinks:f=!0,match:p,maxDepth:m=Number.POSITIVE_INFINITY,skip:d}={}){if(N(e),m<0)return;const t=p?p.map(i=>typeof i==\"string\"?u(i):i):void 0,r=d?d.map(i=>typeof i==\"string\"?u(i):i):void 0;if(e=v(g(e)),s&&l(e,o,t,r)&&(yield await P(e)),!(m<1||!l(e,void 0,void 0,r)))try{for await(const i of await w(e,{withFileTypes:!0})){let n=L(e,i.name);if(i.isSymbolicLink())if(a)n=await D(n);else if(f&&l(n,o,t,r))yield{isDirectory:i.isDirectory,isFile:i.isFile,isSymbolicLink:i.isSymbolicLink,name:i.name,path:n};else continue;i.isSymbolicLink()||i.isDirectory()?yield*b(n,{extensions:o,followSymlinks:a,includeDirs:s,includeFiles:y,includeSymlinks:f,match:t,maxDepth:m-1,skip:r}):i.isFile()&&y&&l(n,o,t,r)&&(yield{isDirectory:i.isDirectory,isFile:i.isFile,isSymbolicLink:i.isSymbolicLink,name:i.name,path:n})}}catch(i){throw i instanceof k?i:new k(i,e)}}c(b,\"d\");S(b,\"walk\");export{b as default};\n","var o=Object.defineProperty;var a=(r,e)=>o(r,\"name\",{value:e,configurable:!0});import t from\"./walk-DH-95i_B.mjs\";var c=Object.defineProperty,i=a((r,e)=>c(r,\"name\",{value:e,configurable:!0}),\"e\");const p=i(async(r,e={})=>{Array.isArray(e.extensions)||(e.extensions=[\"js\",\"mjs\",\"cjs\",\"ts\"]);const s=[];for await(const n of t(r,e))s.push(n.path);return s},\"collect\");export{p as default};\n","import { readdirSync, readFileSync } from \"node:fs\";\n\nimport { parse } from \"@visulima/path\";\nimport type { PackageJson } from \"type-fest\";\n\ninterface AppExport {\n [key: string]: any;\n app?: string | { app?: string };\n}\n\nexport const ALLOWED_EXTENSIONS = [\".js\", \".ts\", \".mjs\", \".cjs\"];\n\nexport const getAppWorkingDirectoryPath = (appFilePath: string): string | null => {\n let lastParsedPath = parse(appFilePath);\n\n // Once the following condition returns false it means we traversed the whole file system\n // eslint-disable-next-line no-loops/no-loops\n while (lastParsedPath.base && lastParsedPath.root !== lastParsedPath.dir) {\n const parentDirectionItems = readdirSync(lastParsedPath.dir);\n\n const packageJSON = parentDirectionItems.find((item) => item === \"package.json\");\n\n if (packageJSON) {\n return lastParsedPath.dir;\n }\n\n lastParsedPath = parse(lastParsedPath.dir);\n }\n\n return null;\n};\n\nexport const getFrameworkName = (directory: string): \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null => {\n const packageJSONFilePath = `${directory}/package.json`;\n\n const { dependencies } = JSON.parse(readFileSync(packageJSONFilePath).toString()) as PackageJson;\n\n if (dependencies?.express) {\n return \"express\";\n }\n\n if (dependencies?.koa && (dependencies[\"@koa/router\"] || dependencies[\"koa-router\"])) {\n return \"koa\";\n }\n\n if (dependencies?.next) {\n return \"next\";\n }\n\n if (dependencies?.[\"@hapi/hapi\"]) {\n return \"hapi\";\n }\n\n if (dependencies?.fastify) {\n return \"fastify\";\n }\n\n return null;\n};\n\nexport const getApp = (appExport: AppExport, frameworkName: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null): AppExport | string | null => {\n const isExportEmpty = Object.keys(appExport).length === 0;\n\n if (isExportEmpty) {\n return null;\n }\n\n if (frameworkName === \"hapi\") {\n if (typeof (appExport.app as { app?: string }).app === \"string\") {\n return appExport.app as { app: string };\n }\n\n return appExport;\n }\n\n return appExport.app ?? appExport;\n};\n","import { statSync } from \"node:fs\";\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/fs\";\nimport { join } from \"@visulima/path\";\n\nimport { ALLOWED_EXTENSIONS } from \"../../utils\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path = \"\"): Promise<string[]> => {\n let apiFolderPath = join(path, \"pages/api\");\n\n // src/pages will be ignored if pages is present in the root directory\n if (!isDirectory(apiFolderPath)) {\n apiFolderPath = join(path, \"src/pages/api\");\n\n if (!isDirectory(apiFolderPath)) {\n return [];\n }\n }\n\n return collect(apiFolderPath, {\n extensions: ALLOWED_EXTENSIONS,\n includeDirs: false,\n });\n};\n\nexport default collectApiRouteFiles;\n","import type { Server } from \"@hapi/hapi\";\nimport type { Express } from \"express\";\nimport type { FastifyInstance } from \"fastify\";\nimport type Koa from \"koa\";\n\nimport expressRoutes from \"./routes/express-routes\";\nimport fastifyRoutes from \"./routes/fastify-routes\";\nimport hapiRoutes from \"./routes/hapi-routes\";\nimport koaRoutes from \"./routes/koa-routes\";\nimport apiRouteFileParser from \"./routes/next/api-route-file-parser\";\nimport collectApiRouteFiles from \"./routes/next/collect-api-route-files\";\nimport type { Route } from \"./routes/types\";\n\nexport type FrameworkName = \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | \"unknown\";\nexport const getRoutes = async (\n appOrPath: Express | FastifyInstance | Koa | Server | string,\n frameworkName: FrameworkName,\n verbose: boolean,\n): Promise<Route[] | null> => {\n if (frameworkName === \"express\") {\n return expressRoutes(appOrPath as Express);\n }\n\n if (frameworkName === \"koa\") {\n return koaRoutes(appOrPath as Koa);\n }\n\n if (frameworkName === \"hapi\") {\n return hapiRoutes(appOrPath as Server);\n }\n\n if (frameworkName === \"fastify\") {\n return fastifyRoutes(appOrPath as FastifyInstance);\n }\n\n if (frameworkName === \"next\") {\n const apiRouteFiles = await collectApiRouteFiles(appOrPath as string);\n\n if (apiRouteFiles.length === 0) {\n throw new Error(`No API routes found, in \"${appOrPath}\".`);\n }\n\n return apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, appOrPath as string, verbose));\n }\n\n return null;\n};\n","import type { Route } from \"./types\";\n\nconst routesGroupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map<string, Route[]>();\n\n list.forEach((item) => {\n const key = keyGetter(item);\n const collection = map.get(key);\n\n if (collection) {\n collection.push(item);\n } else {\n map.set(key, [item]);\n }\n });\n\n return map;\n};\n\nexport default routesGroupBy;\n","import chalk from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n ANY: chalk.redBright,\n DELETE: chalk.redBright,\n GET: chalk.blue,\n HEAD: chalk.hex(\"#6C7280\"),\n OPTIONS: chalk.hex(\"#6C7280\"),\n PATCH: chalk.yellow,\n POST: chalk.yellow,\n PUT: chalk.yellow,\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${chalk.blue(\"GET\")}${chalk.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${chalk.grey(\"|HEAD\")}` : coloredMethod;\n }\n\n const spacesCount = method === \"GET\" ? 6 : 14 - method.length;\n const spaces = Array.from({ length: spacesCount }).fill(\" \").join(\"\");\n\n const dotsCount = process.stdout.columns - 16 - routePath.length - 4;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\".\").join(\"\") : \"\";\n\n const routeText = routePath\n .split(\"/\")\n .map((segment) => {\n const isDynamicSegment = [\":\", \"[\"].includes(segment[0] ?? \"\");\n\n return isDynamicSegment ? chalk.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${chalk.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[] } = {}): (string | undefined)[] =>\n routesMap\n .map((route) => {\n if (Array.isArray(options.methods) && options.methods.includes(route.method)) {\n return;\n }\n\n if (route.method === \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\") {\n // eslint-disable-next-line no-param-reassign\n route.method = \"ANY\";\n }\n\n // eslint-disable-next-line consistent-return\n return renderRoute(route.method, route.path.replace(\"/pages\", \"\"));\n })\n .filter(Boolean);\n\nexport default routesRender;\n","import { execSync } from \"node:child_process\";\nimport { existsSync, rmSync, statSync } from \"node:fs\";\nimport process from \"node:process\";\n\nimport { extname, join } from \"@visulima/path\";\nimport chalk from \"chalk\";\n\nimport { getRoutes } from \"./get-routes\";\nimport routesGroupBy from \"./routes/routes-group-by\";\nimport routesRender from \"./routes/routes-render\";\nimport type { Route } from \"./routes/types\";\nimport { ALLOWED_EXTENSIONS, getApp, getAppWorkingDirectoryPath, getFrameworkName } from \"./utils\";\n\ninterface RenderOptions {\n excludePaths: string[];\n group: string;\n includePaths: string[];\n methods: string[];\n verbose: boolean;\n}\n\nconst listCommand = async (\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | undefined,\n path: string,\n options: Partial<RenderOptions> = {},\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Promise<void> => {\n const frameworkPath = join(process.cwd(), path);\n\n if (!existsSync(frameworkPath)) {\n throw new Error(\"No such file, invalid path provided.\");\n }\n\n const appWorkingDirectoryPath = getAppWorkingDirectoryPath(frameworkPath);\n\n if (!appWorkingDirectoryPath) {\n throw new Error(\"Please initialize local package.json.\");\n }\n\n if (framework === undefined) {\n const frameworkName = getFrameworkName(appWorkingDirectoryPath);\n\n if (!frameworkName) {\n throw new Error(\"Couldn't detect supported back-end framework.\");\n }\n\n // eslint-disable-next-line no-param-reassign\n framework = frameworkName;\n }\n\n let routes: Route[] | null = null;\n\n if (framework === \"next\") {\n routes = await getRoutes(frameworkPath, \"next\", options.verbose ?? false);\n } else {\n if (!statSync(frameworkPath).isFile()) {\n throw new Error(`${frameworkPath} is directory, but file expected.`);\n }\n\n if (!ALLOWED_EXTENSIONS.includes(extname(frameworkPath))) {\n throw new Error(\"Please specify application .ts/.js/.mjs/.cjs file.\");\n }\n\n const environmentFilePath = `${appWorkingDirectoryPath}/.env`;\n\n if (existsSync(environmentFilePath)) {\n // Loads environment vars in the current process so application\n // that depends on them can be loaded properly below\n const dotEnvironmentFilePath = `${appWorkingDirectoryPath}/node_modules/dotenv/lib/main.js`;\n const dotenv = await import(dotEnvironmentFilePath);\n\n dotenv.config({ path: environmentFilePath });\n }\n\n const isTypeScriptApp = extname(frameworkPath) === \".ts\";\n const tscPath = join(appWorkingDirectoryPath, \"node_modules/.bin/tsc\");\n\n if (isTypeScriptApp && !existsSync(tscPath)) {\n throw new Error(`Please install typescript in ${appWorkingDirectoryPath}`);\n }\n\n try {\n if (isTypeScriptApp) {\n // || rm -r ./framework-list removes framework-list directory in case tsc fails\n\n try {\n execSync(`${tscPath} --outDir framework-list >&2`, { cwd: appWorkingDirectoryPath });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log(\"TSC compilation failed. Please resolve issues in your project.\\n\");\n // eslint-disable-next-line no-console\n console.log(error);\n\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n\n const appJsFilePath = isTypeScriptApp\n ? join(appWorkingDirectoryPath, \"framework-list\", frameworkPath.replace(appWorkingDirectoryPath, \"\").replace(\".ts\", \".js\"))\n : frameworkPath;\n\n const { default: defaultExport } = await import(appJsFilePath);\n\n routes = await getRoutes(\n [\"AsyncFunction\", \"Function\"].includes(defaultExport.constructor.name as string) ? await defaultExport() : getApp(defaultExport, framework),\n framework,\n options.verbose ?? false,\n );\n } finally {\n if (isTypeScriptApp) {\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n }\n\n if (routes === null) {\n throw new Error(`Framework \"${framework}\" is not supported.`);\n }\n\n if (Array.isArray(options.includePaths) && options.includePaths.length > 0) {\n routes = options.includePaths.flatMap((ipath) => (routes as Route[]).filter((route) => route.path.startsWith(ipath)));\n }\n\n if (Array.isArray(options.excludePaths) && options.excludePaths.length > 0) {\n routes = options.excludePaths.flatMap((epath) => (routes as Route[]).filter((route) => !route.path.startsWith(epath)));\n }\n\n if (typeof options.group === \"string\" && options.group !== \"\") {\n // eslint-disable-next-line no-console\n console.log();\n\n const groupedMap = routesGroupBy(routes, (route) => {\n if (options.group === \"path\") {\n return route.path.replace(\"/pages\", \"\").split(\"/\")[1];\n }\n\n return route.tags[0] ?? \"unsorted\";\n });\n\n let counter = 0;\n\n groupedMap.forEach((groupedRoutes, key) => {\n if (counter > 0) {\n // eslint-disable-next-line no-console\n console.log();\n }\n\n const dotsCount = (process.stdout.columns - 16 - key.length) / 2;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\" \").join(\"\") : \"\";\n\n // eslint-disable-next-line no-console\n console.log(dots + chalk.bold.underline(key));\n\n routesRender(groupedRoutes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n } else {\n // eslint-disable-next-line no-console\n console.log();\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n }\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${chalk.greenBright(String(routes.length))} HTTP ${routes.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n"]}
@@ -1,6 +0,0 @@
1
- 'use strict';var child_process=require('child_process'),fs=require('fs'),oe=require('process'),path=require('@visulima/path'),d=require('chalk'),jsdocOpenApi=require('@visulima/jsdoc-open-api'),promises=require('fs/promises'),utils=require('@visulima/path/utils');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var oe__default=/*#__PURE__*/_interopDefault(oe);var d__default=/*#__PURE__*/_interopDefault(d);var ne=(e,t)=>{if(t.length===0)throw new Error("must include at least one key to map");let r=e.toString();return t.forEach(o=>{r=o.optional?r.replace("(?:\\/([^\\/]+?))?\\",`/:${o.name}?`):r.replace("(?:([^\\/]+?))",`:${o.name}`);}),r.replace("/?(?=\\/|$)/i","").replace("/^","").replaceAll("\\","").replaceAll(/\/{2,}/gu,"/")},T=ne;var ie=(e,t)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let r="";t.length>0&&(r=T(e,t));let o=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//u.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(o)&&o.length>1?o[1].replaceAll(/\\(.)/gu,"$1").slice(1):r?r.slice(1):e.toString()},F=ie;var pe=(e,t,r)=>{let o=e.route.stack.at(-1),s=t.map(i=>({in:"path",name:i.name,required:!i.optional})),a=e.route.stack.filter(i=>i.handle.metadata);if(a.length>1)throw new Error("Only one metadata middleware is allowed per route");let c=(r+e.route.path).replaceAll(/\/{2,}/gu,"/");return a.length===0?{method:o.method,path:c,pathParams:s}:{metadata:a[0].handle.metadata,method:o.method,path:c,pathParams:s}},j=(e,t,r,o)=>{if(o=[...o,...r.keys],r.name==="router"&&r.handle&&r.handle.stack!==void 0)for(let s of r.handle.stack)t=t||"",j(e,`${t}/${F(r.regexp,r.keys)}`,s,o);!r.route||r.route.stack.length===0||e.push(pe(r,o,t));},ce=e=>{let t=e._router||e.router,r=[];for(let o of t.stack)j(r,"",o,[]);return r},L=ce;var le=e=>{let t=[];return L(e).forEach(r=>{t.push({file:"unknown",method:r.method.toUpperCase(),path:r.path,tags:[]});}),t},$=le;var I=e=>e.replaceAll(/ \(.*\)/gu,"").trim(),C=e=>e.trim().split(" ")[1].slice(1,-1),me=e=>{let r=e.printRoutes().replaceAll(/[─│└├]/gu," ").trimEnd().split(`
2
- `),o=r.reduce((a,c,i)=>{let p=I(c);if(I(r[i-1]??"")===p){let P=a.filter(O=>O.index<i&&O.segment===p),{methods:D}=P.at(-1);return D!==null&&D.push(C(c)),a}let l=c.replaceAll(/ \(.*\)/gu,"").match(/ /gu);if(l===null)throw new Error("Invalid spaces");let n=l.length/4,u=c.includes("("),w=u?[C(c)]:null;return a.push({depth:n,index:i,isRoute:u,methods:w,segment:p}),a},[]),s=[];return o.filter(a=>a.isRoute).forEach(a=>{let i=[...o.filter(p=>p.index<a.index&&p.depth<a.depth).filter((p,m,l)=>!l.find(n=>n.depth===p.depth&&n.index>p.index)).map(p=>p.segment),a.segment].join("");if(a.methods===null)throw new Error("Invalid methods");a.methods.forEach(p=>{s.push({file:"unknown",method:p.toUpperCase(),path:i,tags:[]});});}),s},N=me;var fe=e=>{let r=e._core.router.routes,o=[];return [...r.keys()].forEach(s=>{r.get(s).routes.forEach(a=>{o.push({file:"unknown",method:a.route.method.toUpperCase(),path:a.path,tags:[]});});}),o},_=fe;var ue=e=>{let t=[];return e.middleware.filter(r=>r.router).flatMap(r=>r.router.stack).forEach(r=>{t.push({file:"unknown",method:r.methods.join("|").toUpperCase(),path:r.path,tags:[]});}),t},K=ue;var H=/\.(js|ts|mjs|cjs)$/u,Ee=(e,t,r=!1)=>{e=path.toNamespacedPath(e);let o=path.toNamespacedPath(oe.cwd()),s=[],a=jsdocOpenApi.parseFile(e,jsdocOpenApi.jsDocumentCommentsToOpenApi,r);s=[...s,...a.map(p=>p.spec)];let c=jsdocOpenApi.parseFile(e,jsdocOpenApi.swaggerJsDocumentCommentsToOpenApi,r);s=[...s,...c.map(p=>p.spec)];let i=[];return s.length===0?(fs.readFileSync(e,"utf8").split(/\r?\n/u).forEach(m=>{let l=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/u.exec(m);if(l){let[,n]=l;n==="GET"&&(n="GET|HEAD"),i.push({file:e.replace(`${o}/`,""),method:n,path:path.toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]});}}),i.length===0&&i.push({file:e.replace(`${o}/`,""),method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:path.toNamespacedPath(e.replace(t,"").replace(H,"")),tags:[]}),i):(s.forEach(p=>{Object.entries(p?.paths??{}).forEach(([l,n])=>{Object.entries(n).forEach(([w,P])=>{i.push({file:e.replace(`${o}/`,""),method:w.toUpperCase(),path:path.toNamespacedPath(l),tags:P.tags});});});}),i)},J=Ee;var xe=Object.defineProperty,Se=(e,t)=>xe(e,"name",{value:t,configurable:!0}),we=Object.defineProperty,Pe=Se((e,t)=>we(e,"name",{value:t,configurable:!0}),"n"),U=Pe(e=>{if(!e||!(e instanceof URL)&&typeof e!="string")throw new TypeError("Path must be a non-empty string or URL.")},"assertValidFileOrDirectoryPath");var Re=Object.defineProperty,W=(e,t)=>Re(e,"name",{value:t,configurable:!0}),ke=Object.defineProperty,ve=W((e,t)=>ke(e,"name",{value:t,configurable:!0}),"t"),y=class extends Error{static{W(this,"i");}static{ve(this,"WalkError");}root;constructor(t,r){super(`${t instanceof Error?t.message:t} for path "${r}"`),this.cause=t,this.root=r;}get name(){return "WalkError"}set name(t){throw new Error("Cannot overwrite name of WalkError")}};var be=Object.defineProperty,G=(e,t)=>be(e,"name",{value:t,configurable:!0}),Ae=Object.defineProperty,De=G((e,t)=>Ae(e,"name",{value:t,configurable:!0}),"r"),R=De(e=>{let t=e.replace(/\.\*/g,".([^/]*)").replace(/\*\*/g,"(.*)").replace(/(?<!\.)\*(?!\*)/g,"([^/]*)").replace(/\?/g,"[^/]").replace(/\.(?!\*)/g,"\\.").replace(/\{/g,"(").replace(/\}/g,")").replace(/,/g,"|").replace(/\[!(.*?)\]/g,"[^$1]");return new RegExp(`^${t}$`)},"globToRegExp"),Oe=Object.defineProperty,Te=G((e,t)=>Oe(e,"name",{value:t,configurable:!0}),"n"),g=Te((e,t,r,o)=>Array.isArray(t)&&t.length>0&&!t.some(s=>e.endsWith(s))||r&&!r.some(s=>s.test(e))?!1:!o?.some(s=>s.test(e)),"walkInclude");var Fe=Object.defineProperty,B=(e,t)=>Fe(e,"name",{value:t,configurable:!0}),Me=Object.defineProperty,Y=B((e,t)=>Me(e,"name",{value:t,configurable:!0}),"f"),He=Y(async e=>{let t=path.normalize(e),r=path.basename(t),o=await promises.stat(t);return {isDirectory:o.isDirectory,isFile:o.isFile,isSymbolicLink:o.isSymbolicLink,name:r,path:t}},"_createWalkEntry");async function*E(e,{extensions:t,followSymlinks:r=!1,includeDirs:o=!0,includeFiles:s=!0,includeSymlinks:a=!0,match:c,maxDepth:i=Number.POSITIVE_INFINITY,skip:p}={}){if(U(e),i<0)return;let m=c?c.map(n=>typeof n=="string"?R(n):n):void 0,l=p?p.map(n=>typeof n=="string"?R(n):n):void 0;if(e=path.resolve(utils.toPath(e)),o&&g(e,t,m,l)&&(yield await He(e)),!(i<1||!g(e,void 0,void 0,l)))try{for await(let n of await promises.readdir(e,{withFileTypes:!0})){let u=path.join(e,n.name);if(n.isSymbolicLink())if(r)u=await promises.realpath(u);else if(a&&g(u,t,m,l))yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:u};else continue;n.isSymbolicLink()||n.isDirectory()?yield*E(u,{extensions:t,followSymlinks:r,includeDirs:o,includeFiles:s,includeSymlinks:a,match:m,maxDepth:i-1,skip:l}):n.isFile()&&s&&g(u,t,m,l)&&(yield {isDirectory:n.isDirectory,isFile:n.isFile,isSymbolicLink:n.isSymbolicLink,name:n.name,path:u});}}catch(n){throw n instanceof y?n:new y(n,e)}}B(E,"d");Y(E,"walk");var Je=Object.defineProperty,Ue=(e,t)=>Je(e,"name",{value:t,configurable:!0}),We=Object.defineProperty,Ge=Ue((e,t)=>We(e,"name",{value:t,configurable:!0}),"e"),k=Ge(async(e,t={})=>{Array.isArray(t.extensions)||(t.extensions=["js","mjs","cjs","ts"]);let r=[];for await(let o of E(e,t))r.push(o.path);return r},"collect");var S=[".js",".ts",".mjs",".cjs"],q=e=>{let t=path.parse(e);for(;t.base&&t.root!==t.dir;){if(fs.readdirSync(t.dir).find(s=>s==="package.json"))return t.dir;t=path.parse(t.dir);}return null},V=e=>{let t=`${e}/package.json`,{dependencies:r}=JSON.parse(fs.readFileSync(t).toString());return r?.express?"express":r?.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r?.next?"next":r?.["@hapi/hapi"]?"hapi":r?.fastify?"fastify":null},z=(e,t)=>Object.keys(e).length===0?null:t==="hapi"?typeof e.app.app=="string"?e.app:e:e.app??e;var Z=e=>{try{return fs.statSync(e).isDirectory()}catch{return !1}},qe=async(e="")=>{let t=path.join(e,"pages/api");return !Z(t)&&(t=path.join(e,"src/pages/api"),!Z(t))?[]:k(t,{extensions:S,includeDirs:!1})},ee=qe;var v=async(e,t,r)=>{if(t==="express")return $(e);if(t==="koa")return K(e);if(t==="hapi")return _(e);if(t==="fastify")return N(e);if(t==="next"){let o=await ee(e);if(o.length===0)throw new Error(`No API routes found, in "${e}".`);return o.flatMap(s=>J(s,e,r))}return null};var Ve=(e,t)=>{let r=new Map;return e.forEach(o=>{let s=t(o),a=r.get(s);a?a.push(o):r.set(s,[o]);}),r},te=Ve;var ze=(e,t)=>{let r={ANY:d__default.default.redBright,DELETE:d__default.default.redBright,GET:d__default.default.blue,HEAD:d__default.default.hex("#6C7280"),OPTIONS:d__default.default.hex("#6C7280"),PATCH:d__default.default.yellow,POST:d__default.default.yellow,PUT:d__default.default.yellow},o;if(e==="GET|HEAD")o=`${d__default.default.blue("GET")}${d__default.default.grey("|HEAD")}`;else {let m=r[e](e);o=e==="GET"?`${m}${d__default.default.grey("|HEAD")}`:m;}let s=e==="GET"?6:14-e.length,a=Array.from({length:s}).fill(" ").join(""),c=process.stdout.columns-16-t.length-4,i=c>0?Array.from({length:c}).fill(".").join(""):"",p=t.split("/").map(m=>[":","["].includes(m[0]??"")?d__default.default.yellowBright(m):m).join("/");return ` ${o}${a}${p}${d__default.default.grey(i)}`},Qe=(e,t={})=>e.map(r=>{if(!(Array.isArray(t.methods)&&t.methods.includes(r.method)))return r.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(r.method="ANY"),ze(r.method,r.path.replace("/pages",""))}).filter(Boolean),b=Qe;var tt=async(e,t,r={})=>{let o=path.join(oe__default.default.cwd(),t);if(!fs.existsSync(o))throw new Error("No such file, invalid path provided.");let s=q(o);if(!s)throw new Error("Please initialize local package.json.");if(e===void 0){let c=V(s);if(!c)throw new Error("Couldn't detect supported back-end framework.");e=c;}let a=null;if(e==="next")a=await v(o,"next",r.verbose??!1);else {if(!fs.statSync(o).isFile())throw new Error(`${o} is directory, but file expected.`);if(!S.includes(path.extname(o)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let c=`${s}/.env`;fs.existsSync(c)&&(await import(`${s}/node_modules/dotenv/lib/main.js`)).config({path:c});let i=path.extname(o)===".ts",p=path.join(s,"node_modules/.bin/tsc");if(i&&!fs.existsSync(p))throw new Error(`Please install typescript in ${s}`);try{if(i)try{child_process.execSync(`${p} --outDir framework-list >&2`,{cwd:s});}catch(n){console.log(`TSC compilation failed. Please resolve issues in your project.
3
- `),console.log(n),fs.rmSync(path.join(s,"framework-list"),{recursive:!0});}let m=i?path.join(s,"framework-list",o.replace(s,"").replace(".ts",".js")):o,{default:l}=await import(m);a=await v(["AsyncFunction","Function"].includes(l.constructor.name)?await l():z(l,e),e,r.verbose??!1);}finally{i&&fs.rmSync(path.join(s,"framework-list"),{recursive:!0});}}if(a===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(r.includePaths)&&r.includePaths.length>0&&(a=r.includePaths.flatMap(c=>a.filter(i=>i.path.startsWith(c)))),Array.isArray(r.excludePaths)&&r.excludePaths.length>0&&(a=r.excludePaths.flatMap(c=>a.filter(i=>!i.path.startsWith(c)))),typeof r.group=="string"&&r.group!==""){console.log();let c=te(a,p=>r.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;c.forEach((p,m)=>{i>0&&console.log();let l=(oe__default.default.stdout.columns-16-m.length)/2,n=l>0?Array.from({length:l}).fill(" ").join(""):"";console.log(n+d__default.default.bold.underline(m)),b(p,r).forEach(u=>{console.log(u);}),i+=1;});}else console.log(),b(a,r).forEach(c=>{console.log(c);});console.log(`
4
- Listed ${d__default.default.greenBright(String(a.length))} HTTP ${a.length===1?"route":"routes"}.
5
- `);},Rr=tt;exports.a=Rr;//# sourceMappingURL=chunk-SAMQ6B5Z.js.map
6
- //# sourceMappingURL=chunk-SAMQ6B5Z.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/framework/cli/command/list/routes/express/map-keys-to-path.ts","../src/framework/cli/command/list/routes/express/path-regex-parser.ts","../src/framework/cli/command/list/routes/express/express-path-parser.ts","../src/framework/cli/command/list/routes/express-routes.ts","../src/framework/cli/command/list/routes/fastify-routes.ts","../src/framework/cli/command/list/routes/hapi-routes.ts","../src/framework/cli/command/list/routes/koa-routes.ts","../src/framework/cli/command/list/routes/next/api-route-file-parser.ts","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/assertValidFileOrDirectoryPath-DgPIPmZT.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/WalkError-BsngoIKJ.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/walk-include-B-MbUqMt.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/walk-DH-95i_B.mjs","../../../node_modules/.pnpm/@visulima+fs@2.3.4/node_modules/@visulima/fs/dist/packem_shared/collect-CRzGiRGg.mjs","../src/framework/cli/command/list/utils.ts","../src/framework/cli/command/list/routes/next/collect-api-route-files.ts","../src/framework/cli/command/list/get-routes.ts","../src/framework/cli/command/list/routes/routes-group-by.ts","../src/framework/cli/command/list/routes/routes-render.ts","../src/framework/cli/command/list/list-command.ts"],"names":["mapKeysToPath","layerRegexPath","keys","convertedSubPath","key","map_keys_to_path_default","pathRegexParser","mappedPath","match","path_regex_parser_default","parseRouteLayer","layer","basePath","lastRequestHandler","pathParameters","filtered","element","path","traverse","routes","l","expressPathParser","app","router","express_path_parser_default","expressRoutes","route","express_routes_default","getSegment","line","getMethod","fastifyRoutes","lines","segments","allSegments","index","segment","entries","item","methods","spaces","depth","isRoute","seg","_index","previousArray","r","method","fastify_routes_default","hapiRoutes","coreRoutes","hapi_routes_default","koaRoutes","middlewareFunction","koa_routes_default","extensionRegex","apiRouteFileParser","apiRouteFile","cwd","verbose","toNamespacedPath","cwdPath","nodeCwd","specs","parsedJsDocumentFile","parseFile","jsDocumentCommentsToOpenApi","parsedSwaggerJsDocumentFile","swaggerJsDocumentCommentsToOpenApi","readFileSync","spec","pathSpec","methodSpec","api_route_file_parser_default","a","t","n","o","s","c","p","u","v","g","h","O","S","P","x","I","F","b","y","f","m","d","i","w","L","D","e","ALLOWED_EXTENSIONS","getAppWorkingDirectoryPath","appFilePath","lastParsedPath","parse","readdirSync","getFrameworkName","directory","packageJSONFilePath","dependencies","getApp","appExport","frameworkName","isDirectory","statSync","collectApiRouteFiles","apiFolderPath","join","collect_api_route_files_default","getRoutes","appOrPath","apiRouteFiles","routesGroupBy","list","keyGetter","map","collection","routes_group_by_default","renderRoute","routePath","colorMap","chalk","methodText","coloredMethod","spacesCount","dotsCount","dots","routeText","routesRender","routesMap","options","routes_render_default","listCommand","framework","frameworkPath","process","existsSync","appWorkingDirectoryPath","extname","environmentFilePath","isTypeScriptApp","tscPath","execSync","error","rmSync","appJsFilePath","defaultExport","ipath","epath","groupedMap","counter","groupedRoutes","renderedRoute","list_command_default"],"mappings":"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","file":"chunk-SAMQ6B5Z.js","sourcesContent":["import type { ExpressRegex, Key } from \"./types\";\n\n/**\n * Map's the keys/path variables to the regex inside a given path\n *\n * @param layerRegexPath The regex for a router with path parameters\n * @param keys The keys that represent the path parameters\n *\n * @returns The regex for a path variable converted to original string on the express route\n */\nconst mapKeysToPath = (layerRegexPath: ExpressRegex, keys: Key[]): string => {\n if (keys.length === 0) {\n throw new Error(\"must include at least one key to map\");\n }\n\n let convertedSubPath = layerRegexPath.toString();\n\n keys.forEach((key) => {\n convertedSubPath = key.optional\n ? convertedSubPath.replace(\"(?:\\\\/([^\\\\/]+?))?\\\\\", `/:${key.name}?`)\n : convertedSubPath.replace(\"(?:([^\\\\/]+?))\", `:${key.name}`);\n });\n\n return convertedSubPath\n .replace(\"/?(?=\\\\/|$)/i\", \"\")\n .replace(\"/^\", \"\")\n .replaceAll(\"\\\\\", \"\")\n .replaceAll(/\\/{2,}/gu, \"/\");\n};\n\nexport default mapKeysToPath;\n","import mapKeysToPath from \"./map-keys-to-path\";\nimport type { ExpressRegex, Key } from \"./types\";\n\n/** Parses an express layer's regex and converts it to the original format seen in code.\n *\n * @param layerRegexPath The layer's regex pattern\n * @param keys The keys that represent the layer's path parameters\n * @returns The path string for that layer\n * Code inspired and modify from:\n * https://github.com/expressjs/express/issues/3308#issuecomment-300957572\n */\nconst pathRegexParser = (layerRegexPath: ExpressRegex | string, keys: Key[]): string => {\n if (typeof layerRegexPath === \"string\") {\n return layerRegexPath;\n }\n\n if (layerRegexPath.fast_slash) {\n return \"\";\n }\n\n if (layerRegexPath.fast_star) {\n return \"*\";\n }\n\n let mappedPath = \"\";\n\n if (keys.length > 0) {\n mappedPath = mapKeysToPath(layerRegexPath, keys);\n }\n\n const match = /^\\/\\^((?:\\\\[$()*+./?[\\\\\\]^{|}]|[^$()*+./?[\\\\\\]^{|}])*)\\$\\//u.exec(\n layerRegexPath.toString().replace(\"\\\\/?\", \"\").replace(\"(?=\\\\/|$)\", \"$\"),\n ) as string[];\n\n if (Array.isArray(match) && match.length > 1) {\n return (match[1] as string).replaceAll(/\\\\(.)/gu, \"$1\").slice(1);\n }\n\n if (mappedPath) {\n return mappedPath.slice(1);\n }\n\n return layerRegexPath.toString();\n};\n\nexport default pathRegexParser;\n","import type { Express, Router } from \"express\";\n\nimport pathRegexParser from \"./path-regex-parser\";\nimport type { Key, Layer, Parameter, Route, RouteMetaData } from \"./types\";\n\n/**\n * Parses a route object. Route objects are the leafs of an express router tree\n *\n * @param layer The layer of this route object - represents the stack of middleware and other metadata\n * @param keys The full set of keys for this particular route\n * @param basePath The base path as it was initial declared for this route\n * @returns A ExpressPath object holding the metadata for a given route\n */\nconst parseRouteLayer = (layer: Required<Layer>, keys: Key[], basePath: string): RouteMetaData => {\n const lastRequestHandler = layer.route.stack.at(-1) as Layer;\n const pathParameters: Parameter[] = keys.map((key) => {\n return { in: \"path\", name: key.name, required: !key.optional };\n });\n\n const filtered = layer.route.stack.filter((element) => (element.handle as Route).metadata);\n\n if (filtered.length > 1) {\n throw new Error(\"Only one metadata middleware is allowed per route\");\n }\n\n const path = (basePath + layer.route.path).replaceAll(/\\/{2,}/gu, \"/\");\n\n if (filtered.length === 0) {\n return { method: lastRequestHandler.method, path, pathParams: pathParameters };\n }\n\n return {\n metadata: ((filtered[0] as Layer).handle as Route).metadata,\n method: lastRequestHandler.method,\n path,\n pathParams: pathParameters,\n };\n};\n\n/**\n * Recursive traversal method for the express router and middleware tree.\n *\n * @param routes The array of routes to add to\n * @param path The current path segment that we have traversed so far\n * @param layer The current 'layer' of the router tree\n * @param keys The keys for the parameter's in the current path branch of the traversal\n * @returns void - base case saves result to internal object\n */\nconst traverse = (routes: RouteMetaData[], path: string, layer: Layer, keys: Key[]): void => {\n // eslint-disable-next-line no-param-reassign\n keys = [...keys, ...layer.keys];\n\n if (layer.name === \"router\" && layer.handle && layer.handle.stack !== undefined) {\n for (const l of layer.handle.stack) {\n // eslint-disable-next-line no-param-reassign\n path = path || \"\";\n\n traverse(routes, `${path}/${pathRegexParser(layer.regexp, layer.keys)}`, l as Layer, keys);\n }\n }\n\n if (!layer.route || layer.route.stack.length === 0) {\n return;\n }\n\n routes.push(parseRouteLayer(layer as Required<Layer>, keys, path));\n};\n\n// @TODO use this to parse the express swagger\n\n/**\n * Parses an Express app and generates list of routes with metadata.\n *\n * Can Parse:\n * - Nested Routers and Complex Express Projects\n * - Optional parameters e.g. /:name?\n * - Complex Matching routes e.g. /ma*tch, /ex(ab)?mple\n * - Regex routes e.g. /\\/abc|\\/xyz/\n * - Array of paths e.g. app.get(['/abc', '/xyz']) -> /abc,xyz/\n *\n * @param app The Express app reference. Must be used after all routes have been attached\n *\n * @returns List of routes for this express app with meta-data that has been picked up\n */\nconst expressPathParser = (app: Express): RouteMetaData[] => {\n // eslint-disable-next-line no-underscore-dangle\n const router: Router = app._router || app.router;\n const routes: RouteMetaData[] = [];\n\n for (const layer of router.stack) {\n // @TODO: revisit this type assertion\n traverse(routes, \"\", layer as unknown as Layer, []);\n }\n\n return routes;\n};\n\nexport default expressPathParser;\n","import type { Express } from \"express\";\n\nimport expressPathParser from \"./express/express-path-parser\";\nimport type { RouteMetaData } from \"./express/types\";\nimport type { Route } from \"./types\";\n\nconst expressRoutes = (app: Express): Route[] => {\n const routes: Route[] = [];\n\n expressPathParser(app).forEach((route: RouteMetaData) => {\n routes.push({\n file: \"unknown\",\n method: route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default expressRoutes;\n","import type { FastifyInstance } from \"fastify\";\n\nimport type { Route } from \"./types\";\n\n// \"<spaces> activity (GET)\" -> \"activity\"\nconst getSegment = (line: string) => line.replaceAll(/ \\(.*\\)/gu, \"\").trim();\n\n// \"<spaces> activity (GET)\" -> \"GET\"\nconst getMethod = (line: string) => (line.trim().split(\" \")[1] as string).slice(1, -1);\n\ninterface Segment {\n depth: number;\n index: number;\n isRoute: boolean;\n methods: string[] | null;\n segment: string;\n}\n\nconst fastifyRoutes = (app: FastifyInstance): Route[] => {\n const printedRoutes = app\n .printRoutes()\n .replaceAll(/[─│└├]/gu, \" \")\n .trimEnd();\n\n const lines = printedRoutes.split(\"\\n\");\n\n // eslint-disable-next-line unicorn/no-array-reduce\n const segments = lines.reduce((allSegments: Segment[], line, index) => {\n const segment = getSegment(line);\n const previousSegment = getSegment(lines[index - 1] ?? \"\");\n\n if (previousSegment === segment) {\n const entries: Segment[] = allSegments.filter((item) => item.index < index && item.segment === segment);\n\n const { methods } = entries.at(-1) as Segment;\n\n if (methods !== null) {\n methods.push(getMethod(line));\n }\n\n return allSegments;\n }\n\n // spaces preceding segment / not counting single space between segment and (METHOD)\n const spaces = line.replaceAll(/ \\(.*\\)/gu, \"\").match(/ /gu);\n\n if (spaces === null) {\n throw new Error(\"Invalid spaces\");\n }\n\n const depth = spaces.length / 4;\n const isRoute = line.includes(\"(\");\n const methods = isRoute ? [getMethod(line)] : null;\n\n allSegments.push({\n depth,\n index,\n isRoute,\n methods,\n segment,\n });\n\n return allSegments;\n }, []);\n\n const routes: Route[] = [];\n\n segments\n .filter((item) => item.isRoute)\n .forEach((item) => {\n const ancestorSegments = segments\n .filter((seg) => seg.index < item.index && seg.depth < item.depth)\n // eslint-disable-next-line unicorn/prefer-array-some\n .filter((seg, _index, previousArray) => !previousArray.find((segment) => segment.depth === seg.depth && segment.index > seg.index));\n\n const route = [...ancestorSegments.map((r) => r.segment), item.segment].join(\"\");\n\n if (item.methods === null) {\n throw new Error(\"Invalid methods\");\n }\n\n item.methods.forEach((method: string) => {\n routes.push({\n file: \"unknown\",\n method: method.toUpperCase(),\n path: route,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default fastifyRoutes;\n","import type { Server } from \"@hapi/hapi\";\n\nimport type { Route } from \"./types\";\n\nconst hapiRoutes = (app: Server): Route[] => {\n // @ts-expect-error TS2339: Property '_core' does not exist on type 'Server'. Internal API.\n // eslint-disable-next-line no-underscore-dangle\n const core = app._core as any;\n const coreRoutes = core.router.routes;\n const routes: Route[] = [];\n\n [...coreRoutes.keys()].forEach((method: string) => {\n coreRoutes.get(method).routes.forEach((route: any) => {\n routes.push({\n file: \"unknown\",\n method: route.route.method.toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n });\n\n return routes;\n};\n\nexport default hapiRoutes;\n","import type Koa from \"koa\";\n\nimport type { Route } from \"./types\";\n\nconst koaRoutes = (app: Koa): Route[] => {\n const routes: Route[] = [];\n\n app.middleware\n .filter((middlewareFunction) => (middlewareFunction as any).router)\n\n .flatMap((middlewareFunction) => (middlewareFunction as any).router.stack)\n .forEach((route) => {\n routes.push({\n file: \"unknown\",\n method: route.methods.join(\"|\").toUpperCase(),\n path: route.path,\n tags: [],\n });\n });\n\n return routes;\n};\n\nexport default koaRoutes;\n","import { readFileSync } from \"node:fs\";\nimport { cwd as nodeCwd } from \"node:process\";\n\nimport type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport { toNamespacedPath } from \"@visulima/path\";\n\nimport type { Route } from \"../types\";\n\n// eslint-disable-next-line regexp/no-unused-capturing-group\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/u;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwd: string, verbose = false): Route[] => {\n // eslint-disable-next-line no-param-reassign\n apiRouteFile = toNamespacedPath(apiRouteFile);\n\n const cwdPath = toNamespacedPath(nodeCwd());\n\n let specs: OpenApiObject[] = [];\n\n const parsedJsDocumentFile = parseFile(apiRouteFile, jsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];\n\n const parsedSwaggerJsDocumentFile = parseFile(apiRouteFile, swaggerJsDocumentCommentsToOpenApi, verbose);\n\n specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];\n\n const routes: Route[] = [];\n\n if (specs.length === 0) {\n const apiRouteFileContent = readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/u).forEach((line) => {\n const match = /[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/u.exec(line);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method as string,\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: toNamespacedPath(apiRouteFile.replace(cwd, \"\").replace(extensionRegex, \"\")),\n tags: [],\n });\n }\n\n return routes;\n }\n\n specs.forEach((spec) => {\n const paths = Object.entries(spec?.paths ?? {});\n\n paths.forEach(([path, pathSpec]) => {\n const methods = Object.entries(pathSpec);\n\n methods.forEach(([method, methodSpec]) => {\n routes.push({\n file: apiRouteFile.replace(`${cwdPath}/`, \"\"),\n method: method.toUpperCase(),\n path: toNamespacedPath(path),\n tags: methodSpec.tags,\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","var a=Object.defineProperty;var t=(e,r)=>a(e,\"name\",{value:r,configurable:!0});var n=Object.defineProperty,o=t((e,r)=>n(e,\"name\",{value:r,configurable:!0}),\"n\");const s=o(e=>{if(!e||!(e instanceof URL)&&typeof e!=\"string\")throw new TypeError(\"Path must be a non-empty string or URL.\")},\"assertValidFileOrDirectoryPath\");export{s as default};\n","var o=Object.defineProperty;var t=(e,r)=>o(e,\"name\",{value:r,configurable:!0});var n=Object.defineProperty,s=t((e,r)=>n(e,\"name\",{value:r,configurable:!0}),\"t\");class c extends Error{static{t(this,\"i\")}static{s(this,\"WalkError\")}root;constructor(r,a){super(`${r instanceof Error?r.message:r} for path \"${a}\"`),this.cause=r,this.root=a}get name(){return\"WalkError\"}set name(r){throw new Error(\"Cannot overwrite name of WalkError\")}}export{c as default};\n","var n=Object.defineProperty;var c=(e,r)=>n(e,\"name\",{value:r,configurable:!0});var p=Object.defineProperty,t=c((e,r)=>p(e,\"name\",{value:r,configurable:!0}),\"r\");const u=t(e=>{const r=e.replace(/\\.\\*/g,\".([^/]*)\").replace(/\\*\\*/g,\"(.*)\").replace(/(?<!\\.)\\*(?!\\*)/g,\"([^/]*)\").replace(/\\?/g,\"[^/]\").replace(/\\.(?!\\*)/g,\"\\\\.\").replace(/\\{/g,\"(\").replace(/\\}/g,\")\").replace(/,/g,\"|\").replace(/\\[!(.*?)\\]/g,\"[^$1]\");return new RegExp(`^${r}$`)},\"globToRegExp\");var o=Object.defineProperty,s=c((e,r)=>o(e,\"name\",{value:r,configurable:!0}),\"n\");const v=s((e,r,g,l)=>Array.isArray(r)&&r.length>0&&!r.some(a=>e.endsWith(a))||g&&!g.some(a=>a.test(e))?!1:!l?.some(a=>a.test(e)),\"walkInclude\");export{v as a,u as c};\n","var h=Object.defineProperty;var c=(e,o)=>h(e,\"name\",{value:o,configurable:!0});import{readdir as w,realpath as D,stat as F}from\"node:fs/promises\";import{resolve as v,join as L,normalize as x,basename as I}from\"@visulima/path\";import{toPath as g}from\"@visulima/path/utils\";import k from\"./WalkError-BsngoIKJ.mjs\";import N from\"./assertValidFileOrDirectoryPath-DgPIPmZT.mjs\";import{c as u,a as l}from\"./walk-include-B-MbUqMt.mjs\";var O=Object.defineProperty,S=c((e,o)=>O(e,\"name\",{value:o,configurable:!0}),\"f\");const P=S(async e=>{const o=x(e),a=I(o),s=await F(o);return{isDirectory:s.isDirectory,isFile:s.isFile,isSymbolicLink:s.isSymbolicLink,name:a,path:o}},\"_createWalkEntry\");async function*b(e,{extensions:o,followSymlinks:a=!1,includeDirs:s=!0,includeFiles:y=!0,includeSymlinks:f=!0,match:p,maxDepth:m=Number.POSITIVE_INFINITY,skip:d}={}){if(N(e),m<0)return;const t=p?p.map(i=>typeof i==\"string\"?u(i):i):void 0,r=d?d.map(i=>typeof i==\"string\"?u(i):i):void 0;if(e=v(g(e)),s&&l(e,o,t,r)&&(yield await P(e)),!(m<1||!l(e,void 0,void 0,r)))try{for await(const i of await w(e,{withFileTypes:!0})){let n=L(e,i.name);if(i.isSymbolicLink())if(a)n=await D(n);else if(f&&l(n,o,t,r))yield{isDirectory:i.isDirectory,isFile:i.isFile,isSymbolicLink:i.isSymbolicLink,name:i.name,path:n};else continue;i.isSymbolicLink()||i.isDirectory()?yield*b(n,{extensions:o,followSymlinks:a,includeDirs:s,includeFiles:y,includeSymlinks:f,match:t,maxDepth:m-1,skip:r}):i.isFile()&&y&&l(n,o,t,r)&&(yield{isDirectory:i.isDirectory,isFile:i.isFile,isSymbolicLink:i.isSymbolicLink,name:i.name,path:n})}}catch(i){throw i instanceof k?i:new k(i,e)}}c(b,\"d\");S(b,\"walk\");export{b as default};\n","var o=Object.defineProperty;var a=(r,e)=>o(r,\"name\",{value:e,configurable:!0});import t from\"./walk-DH-95i_B.mjs\";var c=Object.defineProperty,i=a((r,e)=>c(r,\"name\",{value:e,configurable:!0}),\"e\");const p=i(async(r,e={})=>{Array.isArray(e.extensions)||(e.extensions=[\"js\",\"mjs\",\"cjs\",\"ts\"]);const s=[];for await(const n of t(r,e))s.push(n.path);return s},\"collect\");export{p as default};\n","import { readdirSync, readFileSync } from \"node:fs\";\n\nimport { parse } from \"@visulima/path\";\nimport type { PackageJson } from \"type-fest\";\n\ninterface AppExport {\n [key: string]: any;\n app?: string | { app?: string };\n}\n\nexport const ALLOWED_EXTENSIONS = [\".js\", \".ts\", \".mjs\", \".cjs\"];\n\nexport const getAppWorkingDirectoryPath = (appFilePath: string): string | null => {\n let lastParsedPath = parse(appFilePath);\n\n // Once the following condition returns false it means we traversed the whole file system\n // eslint-disable-next-line no-loops/no-loops\n while (lastParsedPath.base && lastParsedPath.root !== lastParsedPath.dir) {\n const parentDirectionItems = readdirSync(lastParsedPath.dir);\n\n const packageJSON = parentDirectionItems.find((item) => item === \"package.json\");\n\n if (packageJSON) {\n return lastParsedPath.dir;\n }\n\n lastParsedPath = parse(lastParsedPath.dir);\n }\n\n return null;\n};\n\nexport const getFrameworkName = (directory: string): \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null => {\n const packageJSONFilePath = `${directory}/package.json`;\n\n const { dependencies } = JSON.parse(readFileSync(packageJSONFilePath).toString()) as PackageJson;\n\n if (dependencies?.express) {\n return \"express\";\n }\n\n if (dependencies?.koa && (dependencies[\"@koa/router\"] || dependencies[\"koa-router\"])) {\n return \"koa\";\n }\n\n if (dependencies?.next) {\n return \"next\";\n }\n\n if (dependencies?.[\"@hapi/hapi\"]) {\n return \"hapi\";\n }\n\n if (dependencies?.fastify) {\n return \"fastify\";\n }\n\n return null;\n};\n\nexport const getApp = (appExport: AppExport, frameworkName: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | null): AppExport | string | null => {\n const isExportEmpty = Object.keys(appExport).length === 0;\n\n if (isExportEmpty) {\n return null;\n }\n\n if (frameworkName === \"hapi\") {\n if (typeof (appExport.app as { app?: string }).app === \"string\") {\n return appExport.app as { app: string };\n }\n\n return appExport;\n }\n\n return appExport.app ?? appExport;\n};\n","import { statSync } from \"node:fs\";\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/fs\";\nimport { join } from \"@visulima/path\";\n\nimport { ALLOWED_EXTENSIONS } from \"../../utils\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path = \"\"): Promise<string[]> => {\n let apiFolderPath = join(path, \"pages/api\");\n\n // src/pages will be ignored if pages is present in the root directory\n if (!isDirectory(apiFolderPath)) {\n apiFolderPath = join(path, \"src/pages/api\");\n\n if (!isDirectory(apiFolderPath)) {\n return [];\n }\n }\n\n return collect(apiFolderPath, {\n extensions: ALLOWED_EXTENSIONS,\n includeDirs: false,\n });\n};\n\nexport default collectApiRouteFiles;\n","import type { Server } from \"@hapi/hapi\";\nimport type { Express } from \"express\";\nimport type { FastifyInstance } from \"fastify\";\nimport type Koa from \"koa\";\n\nimport expressRoutes from \"./routes/express-routes\";\nimport fastifyRoutes from \"./routes/fastify-routes\";\nimport hapiRoutes from \"./routes/hapi-routes\";\nimport koaRoutes from \"./routes/koa-routes\";\nimport apiRouteFileParser from \"./routes/next/api-route-file-parser\";\nimport collectApiRouteFiles from \"./routes/next/collect-api-route-files\";\nimport type { Route } from \"./routes/types\";\n\nexport type FrameworkName = \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | \"unknown\";\nexport const getRoutes = async (\n appOrPath: Express | FastifyInstance | Koa | Server | string,\n frameworkName: FrameworkName,\n verbose: boolean,\n): Promise<Route[] | null> => {\n if (frameworkName === \"express\") {\n return expressRoutes(appOrPath as Express);\n }\n\n if (frameworkName === \"koa\") {\n return koaRoutes(appOrPath as Koa);\n }\n\n if (frameworkName === \"hapi\") {\n return hapiRoutes(appOrPath as Server);\n }\n\n if (frameworkName === \"fastify\") {\n return fastifyRoutes(appOrPath as FastifyInstance);\n }\n\n if (frameworkName === \"next\") {\n const apiRouteFiles = await collectApiRouteFiles(appOrPath as string);\n\n if (apiRouteFiles.length === 0) {\n throw new Error(`No API routes found, in \"${appOrPath}\".`);\n }\n\n return apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, appOrPath as string, verbose));\n }\n\n return null;\n};\n","import type { Route } from \"./types\";\n\nconst routesGroupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map<string, Route[]>();\n\n list.forEach((item) => {\n const key = keyGetter(item);\n const collection = map.get(key);\n\n if (collection) {\n collection.push(item);\n } else {\n map.set(key, [item]);\n }\n });\n\n return map;\n};\n\nexport default routesGroupBy;\n","import chalk from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n ANY: chalk.redBright,\n DELETE: chalk.redBright,\n GET: chalk.blue,\n HEAD: chalk.hex(\"#6C7280\"),\n OPTIONS: chalk.hex(\"#6C7280\"),\n PATCH: chalk.yellow,\n POST: chalk.yellow,\n PUT: chalk.yellow,\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${chalk.blue(\"GET\")}${chalk.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${chalk.grey(\"|HEAD\")}` : coloredMethod;\n }\n\n const spacesCount = method === \"GET\" ? 6 : 14 - method.length;\n const spaces = Array.from({ length: spacesCount }).fill(\" \").join(\"\");\n\n const dotsCount = process.stdout.columns - 16 - routePath.length - 4;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\".\").join(\"\") : \"\";\n\n const routeText = routePath\n .split(\"/\")\n .map((segment) => {\n const isDynamicSegment = [\":\", \"[\"].includes(segment[0] ?? \"\");\n\n return isDynamicSegment ? chalk.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${chalk.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[] } = {}): (string | undefined)[] =>\n routesMap\n .map((route) => {\n if (Array.isArray(options.methods) && options.methods.includes(route.method)) {\n return;\n }\n\n if (route.method === \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\") {\n // eslint-disable-next-line no-param-reassign\n route.method = \"ANY\";\n }\n\n // eslint-disable-next-line consistent-return\n return renderRoute(route.method, route.path.replace(\"/pages\", \"\"));\n })\n .filter(Boolean);\n\nexport default routesRender;\n","import { execSync } from \"node:child_process\";\nimport { existsSync, rmSync, statSync } from \"node:fs\";\nimport process from \"node:process\";\n\nimport { extname, join } from \"@visulima/path\";\nimport chalk from \"chalk\";\n\nimport { getRoutes } from \"./get-routes\";\nimport routesGroupBy from \"./routes/routes-group-by\";\nimport routesRender from \"./routes/routes-render\";\nimport type { Route } from \"./routes/types\";\nimport { ALLOWED_EXTENSIONS, getApp, getAppWorkingDirectoryPath, getFrameworkName } from \"./utils\";\n\ninterface RenderOptions {\n excludePaths: string[];\n group: string;\n includePaths: string[];\n methods: string[];\n verbose: boolean;\n}\n\nconst listCommand = async (\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\" | undefined,\n path: string,\n options: Partial<RenderOptions> = {},\n // eslint-disable-next-line sonarjs/cognitive-complexity\n): Promise<void> => {\n const frameworkPath = join(process.cwd(), path);\n\n if (!existsSync(frameworkPath)) {\n throw new Error(\"No such file, invalid path provided.\");\n }\n\n const appWorkingDirectoryPath = getAppWorkingDirectoryPath(frameworkPath);\n\n if (!appWorkingDirectoryPath) {\n throw new Error(\"Please initialize local package.json.\");\n }\n\n if (framework === undefined) {\n const frameworkName = getFrameworkName(appWorkingDirectoryPath);\n\n if (!frameworkName) {\n throw new Error(\"Couldn't detect supported back-end framework.\");\n }\n\n // eslint-disable-next-line no-param-reassign\n framework = frameworkName;\n }\n\n let routes: Route[] | null = null;\n\n if (framework === \"next\") {\n routes = await getRoutes(frameworkPath, \"next\", options.verbose ?? false);\n } else {\n if (!statSync(frameworkPath).isFile()) {\n throw new Error(`${frameworkPath} is directory, but file expected.`);\n }\n\n if (!ALLOWED_EXTENSIONS.includes(extname(frameworkPath))) {\n throw new Error(\"Please specify application .ts/.js/.mjs/.cjs file.\");\n }\n\n const environmentFilePath = `${appWorkingDirectoryPath}/.env`;\n\n if (existsSync(environmentFilePath)) {\n // Loads environment vars in the current process so application\n // that depends on them can be loaded properly below\n const dotEnvironmentFilePath = `${appWorkingDirectoryPath}/node_modules/dotenv/lib/main.js`;\n const dotenv = await import(dotEnvironmentFilePath);\n\n dotenv.config({ path: environmentFilePath });\n }\n\n const isTypeScriptApp = extname(frameworkPath) === \".ts\";\n const tscPath = join(appWorkingDirectoryPath, \"node_modules/.bin/tsc\");\n\n if (isTypeScriptApp && !existsSync(tscPath)) {\n throw new Error(`Please install typescript in ${appWorkingDirectoryPath}`);\n }\n\n try {\n if (isTypeScriptApp) {\n // || rm -r ./framework-list removes framework-list directory in case tsc fails\n\n try {\n execSync(`${tscPath} --outDir framework-list >&2`, { cwd: appWorkingDirectoryPath });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log(\"TSC compilation failed. Please resolve issues in your project.\\n\");\n // eslint-disable-next-line no-console\n console.log(error);\n\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n\n const appJsFilePath = isTypeScriptApp\n ? join(appWorkingDirectoryPath, \"framework-list\", frameworkPath.replace(appWorkingDirectoryPath, \"\").replace(\".ts\", \".js\"))\n : frameworkPath;\n\n const { default: defaultExport } = await import(appJsFilePath);\n\n routes = await getRoutes(\n [\"AsyncFunction\", \"Function\"].includes(defaultExport.constructor.name as string) ? await defaultExport() : getApp(defaultExport, framework),\n framework,\n options.verbose ?? false,\n );\n } finally {\n if (isTypeScriptApp) {\n rmSync(join(appWorkingDirectoryPath, \"framework-list\"), { recursive: true });\n }\n }\n }\n\n if (routes === null) {\n throw new Error(`Framework \"${framework}\" is not supported.`);\n }\n\n if (Array.isArray(options.includePaths) && options.includePaths.length > 0) {\n routes = options.includePaths.flatMap((ipath) => (routes as Route[]).filter((route) => route.path.startsWith(ipath)));\n }\n\n if (Array.isArray(options.excludePaths) && options.excludePaths.length > 0) {\n routes = options.excludePaths.flatMap((epath) => (routes as Route[]).filter((route) => !route.path.startsWith(epath)));\n }\n\n if (typeof options.group === \"string\" && options.group !== \"\") {\n // eslint-disable-next-line no-console\n console.log();\n\n const groupedMap = routesGroupBy(routes, (route) => {\n if (options.group === \"path\") {\n return route.path.replace(\"/pages\", \"\").split(\"/\")[1];\n }\n\n return route.tags[0] ?? \"unsorted\";\n });\n\n let counter = 0;\n\n groupedMap.forEach((groupedRoutes, key) => {\n if (counter > 0) {\n // eslint-disable-next-line no-console\n console.log();\n }\n\n const dotsCount = (process.stdout.columns - 16 - key.length) / 2;\n const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(\" \").join(\"\") : \"\";\n\n // eslint-disable-next-line no-console\n console.log(dots + chalk.bold.underline(key));\n\n routesRender(groupedRoutes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n } else {\n // eslint-disable-next-line no-console\n console.log();\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n }\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${chalk.greenBright(String(routes.length))} HTTP ${routes.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n"]}