@visulima/api-platform 1.1.2 → 1.1.3
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 +7 -0
- package/dist/chunk-AG2ROSSA.mjs +2 -0
- package/dist/{chunk-D5JLMBFH.mjs.map → chunk-AG2ROSSA.mjs.map} +1 -1
- package/dist/chunk-HONWWBY6.mjs +2 -0
- package/dist/{chunk-YR2QJYUL.mjs.map → chunk-HONWWBY6.mjs.map} +1 -1
- package/dist/chunk-JXD3457O.js +2 -0
- package/dist/chunk-JXD3457O.js.map +1 -0
- package/dist/chunk-M7LGAQP3.mjs +10 -0
- package/dist/{chunk-EGE7A4ZK.mjs.map → chunk-M7LGAQP3.mjs.map} +1 -1
- package/dist/chunk-OUWZ2PU5.js +2 -0
- package/dist/{chunk-JC4IRQUL.js.map → chunk-OUWZ2PU5.js.map} +0 -0
- package/dist/chunk-QIHOLJVA.js +2 -0
- package/dist/chunk-QIHOLJVA.js.map +1 -0
- package/dist/chunk-UI23SSBN.js +10 -0
- package/dist/chunk-UI23SSBN.js.map +1 -0
- package/dist/chunk-YOXCJZNX.mjs +2 -0
- package/dist/{chunk-5VRACIDE.mjs.map → chunk-YOXCJZNX.mjs.map} +0 -0
- package/dist/index-browser.js +1 -7
- package/dist/index-browser.mjs +1 -7
- package/dist/index-server.d.ts +1 -1
- package/dist/index-server.js +1 -452
- package/dist/index-server.js.map +1 -1
- package/dist/index-server.mjs +1 -452
- package/dist/index-server.mjs.map +1 -1
- package/dist/next/cli/index.js +3 -202
- package/dist/next/cli/index.js.map +1 -1
- package/dist/next/cli/index.mjs +3 -202
- package/dist/next/cli/index.mjs.map +1 -1
- package/dist/next/index-browser.js +1 -11
- package/dist/next/index-browser.mjs +1 -11
- package/dist/next/index-server.js +1 -75
- package/dist/next/index-server.js.map +1 -1
- package/dist/next/index-server.mjs +1 -75
- package/dist/next/index-server.mjs.map +1 -1
- package/package.json +2 -2
- package/dist/chunk-5VRACIDE.mjs +0 -10
- package/dist/chunk-CVURPKKG.js +0 -120
- package/dist/chunk-CVURPKKG.js.map +0 -1
- package/dist/chunk-D5JLMBFH.mjs +0 -284
- package/dist/chunk-EGE7A4ZK.mjs +0 -120
- package/dist/chunk-HOWWQBSN.js +0 -99
- package/dist/chunk-HOWWQBSN.js.map +0 -1
- package/dist/chunk-JC4IRQUL.js +0 -10
- package/dist/chunk-R6HXY2JR.js +0 -284
- package/dist/chunk-R6HXY2JR.js.map +0 -1
- package/dist/chunk-YR2QJYUL.mjs +0 -99
package/dist/next/cli/index.js
CHANGED
|
@@ -1,203 +1,4 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }require('../../chunk-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var _chalk = require('chalk'); var _chalk2 = _interopRequireDefault(_chalk);
|
|
5
|
-
var _path = require('path');
|
|
6
|
-
var _process = require('process'); var _process2 = _interopRequireDefault(_process);
|
|
7
|
-
|
|
8
|
-
// src/next/cli/list/api-route-file-parser.ts
|
|
9
|
-
var _jsdocopenapi = require('@visulima/jsdoc-open-api');
|
|
10
|
-
var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs);
|
|
11
|
-
|
|
12
|
-
var extensionRegex = /\.(js|ts|mjs|cjs)$/;
|
|
13
|
-
var apiRouteFileParser = (apiRouteFile, cwdPath, verbose = false) => {
|
|
14
|
-
let specs = [];
|
|
15
|
-
const parsedJsDocumentFile = _jsdocopenapi.parseFile.call(void 0, apiRouteFile, _jsdocopenapi.jsDocumentCommentsToOpenApi, verbose);
|
|
16
|
-
specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];
|
|
17
|
-
const parsedSwaggerJsDocumentFile = _jsdocopenapi.parseFile.call(void 0, apiRouteFile, _jsdocopenapi.swaggerJsDocumentCommentsToOpenApi, verbose);
|
|
18
|
-
specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];
|
|
19
|
-
const routes = [];
|
|
20
|
-
if (specs.length === 0) {
|
|
21
|
-
const apiRouteFileContent = _fs2.default.readFileSync(apiRouteFile, "utf8");
|
|
22
|
-
apiRouteFileContent.split(/\r?\n/).forEach((line) => {
|
|
23
|
-
const match = line.match(/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/);
|
|
24
|
-
if (match) {
|
|
25
|
-
let [, method] = match;
|
|
26
|
-
if (method === "GET") {
|
|
27
|
-
method = "GET|HEAD";
|
|
28
|
-
}
|
|
29
|
-
routes.push({
|
|
30
|
-
method,
|
|
31
|
-
path: apiRouteFile.replace(cwdPath, "").replace(extensionRegex, ""),
|
|
32
|
-
tags: [],
|
|
33
|
-
file: apiRouteFile.replace(`${_process2.default.cwd()}/`, "")
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
if (routes.length === 0) {
|
|
38
|
-
routes.push({
|
|
39
|
-
method: "GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",
|
|
40
|
-
path: apiRouteFile.replace(cwdPath, "").replace(extensionRegex, ""),
|
|
41
|
-
tags: [],
|
|
42
|
-
file: apiRouteFile.replace(`${_process2.default.cwd()}/`, "")
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
return routes;
|
|
46
|
-
}
|
|
47
|
-
specs.forEach((spec) => {
|
|
48
|
-
const paths = Object.entries(spec.paths);
|
|
49
|
-
paths.forEach(([path, pathSpec]) => {
|
|
50
|
-
const methods = Object.entries(pathSpec);
|
|
51
|
-
methods.forEach(([method, methodSpec]) => {
|
|
52
|
-
routes.push({
|
|
53
|
-
path,
|
|
54
|
-
method: method.toUpperCase(),
|
|
55
|
-
tags: methodSpec.tags,
|
|
56
|
-
file: apiRouteFile.replace(`${_process2.default.cwd()}/`, "")
|
|
57
|
-
});
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
return routes;
|
|
62
|
-
};
|
|
63
|
-
var api_route_file_parser_default = apiRouteFileParser;
|
|
64
|
-
|
|
65
|
-
// src/next/cli/list/collect-api-route-files.ts
|
|
66
|
-
var _readdir = require('@visulima/readdir');
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
var isDirectory = (path) => {
|
|
70
|
-
try {
|
|
71
|
-
return _fs2.default.statSync(path).isDirectory();
|
|
72
|
-
} catch (e) {
|
|
73
|
-
return false;
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
var collectApiRouteFiles = async (path = "", verbose = false) => {
|
|
77
|
-
let apiFolderPath = _path.join.call(void 0, path, "pages/api");
|
|
78
|
-
if (!isDirectory(apiFolderPath)) {
|
|
79
|
-
apiFolderPath = _path.join.call(void 0, path, "src/pages/api");
|
|
80
|
-
if (!isDirectory(apiFolderPath)) {
|
|
81
|
-
return [];
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
return _readdir.collect.call(void 0, apiFolderPath, {
|
|
85
|
-
extensions: [".js", ".cjs", ".mjs", ".ts"],
|
|
86
|
-
includeDirs: false,
|
|
87
|
-
minimatchOptions: {
|
|
88
|
-
match: {
|
|
89
|
-
debug: verbose,
|
|
90
|
-
matchBase: true
|
|
91
|
-
},
|
|
92
|
-
skip: {
|
|
93
|
-
debug: verbose,
|
|
94
|
-
matchBase: true
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
};
|
|
99
|
-
var collect_api_route_files_default = collectApiRouteFiles;
|
|
100
|
-
|
|
101
|
-
// src/next/cli/list/routes-render.ts
|
|
102
|
-
|
|
103
|
-
var renderRoute = (method, routePath) => {
|
|
104
|
-
const colorMap = {
|
|
105
|
-
GET: _chalk2.default.blue,
|
|
106
|
-
POST: _chalk2.default.yellow,
|
|
107
|
-
PATCH: _chalk2.default.yellow,
|
|
108
|
-
PUT: _chalk2.default.yellow,
|
|
109
|
-
DELETE: _chalk2.default.redBright,
|
|
110
|
-
OPTIONS: _chalk2.default.hex("#6C7280"),
|
|
111
|
-
ANY: _chalk2.default.redBright,
|
|
112
|
-
HEAD: _chalk2.default.hex("#6C7280")
|
|
113
|
-
};
|
|
114
|
-
let methodText;
|
|
115
|
-
if (method === "GET|HEAD") {
|
|
116
|
-
methodText = `${_chalk2.default.blue("GET")}${_chalk2.default.grey("|HEAD")}`;
|
|
117
|
-
} else {
|
|
118
|
-
const coloredMethod = colorMap[method](method);
|
|
119
|
-
methodText = method === "GET" ? `${coloredMethod}${_chalk2.default.grey("|HEAD")}` : coloredMethod;
|
|
120
|
-
}
|
|
121
|
-
const spacesCount = method === "GET" ? 6 : 14 - method.length;
|
|
122
|
-
const spaces = Array.from({ length: spacesCount }).fill(" ").join("");
|
|
123
|
-
const dotsCount = process.stdout.columns - 16 - routePath.length - 4;
|
|
124
|
-
const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(".").join("") : "";
|
|
125
|
-
const routeText = routePath.split("/").map((segment) => {
|
|
126
|
-
const isDynamicSegment = ["[", ":"].includes(segment[0] || "");
|
|
127
|
-
return isDynamicSegment ? _chalk2.default.yellowBright(segment) : segment;
|
|
128
|
-
}).join("/");
|
|
129
|
-
return ` ${methodText}${spaces}${routeText}${_chalk2.default.grey(dots)}`;
|
|
130
|
-
};
|
|
131
|
-
var routesRender = (routesMap, options = {}) => routesMap.map((route) => {
|
|
132
|
-
if (options.methods && options.methods.includes(route.method)) {
|
|
133
|
-
return;
|
|
134
|
-
}
|
|
135
|
-
if (route.method === "GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS") {
|
|
136
|
-
route.method = "ANY";
|
|
137
|
-
}
|
|
138
|
-
return renderRoute(route.method, route.path.replace("/pages", ""));
|
|
139
|
-
}).filter(Boolean);
|
|
140
|
-
var routes_render_default = routesRender;
|
|
141
|
-
|
|
142
|
-
// src/next/cli/list/list-command.ts
|
|
143
|
-
var groupBy = (list, keyGetter) => {
|
|
144
|
-
const map = /* @__PURE__ */ new Map();
|
|
145
|
-
list.forEach((item) => {
|
|
146
|
-
const key = keyGetter(item);
|
|
147
|
-
const collection = map.get(key);
|
|
148
|
-
if (collection) {
|
|
149
|
-
collection.push(item);
|
|
150
|
-
} else {
|
|
151
|
-
map.set(key, [item]);
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
return map;
|
|
155
|
-
};
|
|
156
|
-
var listCommand = async (path = "", options = {}) => {
|
|
157
|
-
const routePath = _path.join.call(void 0, _process2.default.cwd(), path);
|
|
158
|
-
const apiRouteFiles = await collect_api_route_files_default(routePath, options.verbose || false);
|
|
159
|
-
if (apiRouteFiles.length === 0) {
|
|
160
|
-
console.error(`No API routes found, in "${routePath}".`);
|
|
161
|
-
_process2.default.exit(1);
|
|
162
|
-
}
|
|
163
|
-
let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => api_route_file_parser_default(apiRouteFile, routePath, options.verbose || false));
|
|
164
|
-
if (options.includePaths) {
|
|
165
|
-
parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));
|
|
166
|
-
}
|
|
167
|
-
if (options.excludePaths) {
|
|
168
|
-
parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));
|
|
169
|
-
}
|
|
170
|
-
if (options.group === void 0) {
|
|
171
|
-
routes_render_default([], options).forEach((renderedRoute) => {
|
|
172
|
-
console.log(renderedRoute);
|
|
173
|
-
});
|
|
174
|
-
} else {
|
|
175
|
-
const groupedMap = groupBy(parsedApiRoutes, (route) => {
|
|
176
|
-
if (options.group === "path") {
|
|
177
|
-
return route.path.replace("/pages", "").split("/")[1];
|
|
178
|
-
}
|
|
179
|
-
return route.tags[0] || "unsorted";
|
|
180
|
-
});
|
|
181
|
-
let counter = 0;
|
|
182
|
-
groupedMap.forEach((routes, key) => {
|
|
183
|
-
if (counter > 0) {
|
|
184
|
-
console.log();
|
|
185
|
-
}
|
|
186
|
-
const dotsCount = (_process2.default.stdout.columns - 16 - key.length) / 2;
|
|
187
|
-
const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(" ").join("") : "";
|
|
188
|
-
console.log(dots + _chalk2.default.bold.underline(key));
|
|
189
|
-
routes_render_default(routes, options).forEach((renderedRoute) => {
|
|
190
|
-
console.log(renderedRoute);
|
|
191
|
-
});
|
|
192
|
-
counter += 1;
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
console.log(`
|
|
196
|
-
Listed ${_chalk2.default.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? "route" : "routes"}.
|
|
197
|
-
`);
|
|
198
|
-
};
|
|
199
|
-
var list_command_default = listCommand;
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
exports.listCommand = list_command_default;
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }require('../../chunk-OUWZ2PU5.js');var _chalk = require('chalk'); var _chalk2 = _interopRequireDefault(_chalk);var _path = require('path');var _process = require('process'); var _process2 = _interopRequireDefault(_process);var _jsdocopenapi = require('@visulima/jsdoc-open-api');var _fs = require('fs'); var _fs2 = _interopRequireDefault(_fs);var E=/\.(js|ts|mjs|cjs)$/,$=(e,t,o=!1)=>{let s=[],i=_jsdocopenapi.parseFile.call(void 0, e,_jsdocopenapi.jsDocumentCommentsToOpenApi,o);s=[...s,...i.map(l=>l.spec)];let r=_jsdocopenapi.parseFile.call(void 0, e,_jsdocopenapi.swaggerJsDocumentCommentsToOpenApi,o);s=[...s,...r.map(l=>l.spec)];let n=[];return s.length===0?(_fs2.default.readFileSync(e,"utf8").split(/\r?\n/).forEach(m=>{let c=m.match(/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/);if(c){let[,p]=c;p==="GET"&&(p="GET|HEAD"),n.push({method:p,path:e.replace(t,"").replace(E,""),tags:[],file:e.replace(`${_process2.default.cwd()}/`,"")})}}),n.length===0&&n.push({method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:e.replace(t,"").replace(E,""),tags:[],file:e.replace(`${_process2.default.cwd()}/`,"")}),n):(s.forEach(l=>{Object.entries(l.paths).forEach(([c,p])=>{Object.entries(p).forEach(([D,j])=>{n.push({path:c,method:D.toUpperCase(),tags:j.tags,file:e.replace(`${_process2.default.cwd()}/`,"")})})})}),n)},T=$;var _readdir = require('@visulima/readdir');var P=e=>{try{return _fs2.default.statSync(e).isDirectory()}catch (e2){return!1}},H=async(e="",t=!1)=>{let o=_path.join.call(void 0, e,"pages/api");return!P(o)&&(o=_path.join.call(void 0, e,"src/pages/api"),!P(o))?[]:_readdir.collect.call(void 0, o,{extensions:[".js",".cjs",".mjs",".ts"],includeDirs:!1,minimatchOptions:{match:{debug:t,matchBase:!0},skip:{debug:t,matchBase:!0}}})},A=H;var w=(e,t)=>{let o={GET:_chalk2.default.blue,POST:_chalk2.default.yellow,PATCH:_chalk2.default.yellow,PUT:_chalk2.default.yellow,DELETE:_chalk2.default.redBright,OPTIONS:_chalk2.default.hex("#6C7280"),ANY:_chalk2.default.redBright,HEAD:_chalk2.default.hex("#6C7280")},s;if(e==="GET|HEAD")s=`${_chalk2.default.blue("GET")}${_chalk2.default.grey("|HEAD")}`;else{let c=o[e](e);s=e==="GET"?`${c}${_chalk2.default.grey("|HEAD")}`:c}let i=e==="GET"?6:14-e.length,r=Array.from({length:i}).fill(" ").join(""),n=process.stdout.columns-16-t.length-4,l=n>0?Array.from({length:n}).fill(".").join(""):"",m=t.split("/").map(c=>["[",":"].includes(c[0]||"")?_chalk2.default.yellowBright(c):c).join("/");return` ${s}${r}${m}${_chalk2.default.grey(l)}`},G=(e,t={})=>e.map(o=>{if(!(t.methods&&t.methods.includes(o.method)))return o.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(o.method="ANY"),w(o.method,o.path.replace("/pages",""))}).filter(Boolean),u=G;var B=(e,t)=>{let o=new Map;return e.forEach(s=>{let i=t(s),r=o.get(i);r?r.push(s):o.set(i,[s])}),o},N=async(e="",t={})=>{let o=_path.join.call(void 0, _process2.default.cwd(),e),s=await A(o,t.verbose||!1);s.length===0&&(console.error(`No API routes found, in "${o}".`),_process2.default.exit(1));let i=s.flatMap(r=>T(r,o,t.verbose||!1));if(t.includePaths&&(i=t.includePaths.flatMap(r=>i.filter(n=>n.path.startsWith(r)))),t.excludePaths&&(i=t.excludePaths.flatMap(r=>i.filter(n=>!n.path.startsWith(r)))),t.group===void 0)u([],t).forEach(r=>{console.log(r)});else{let r=B(i,l=>t.group==="path"?l.path.replace("/pages","").split("/")[1]:l.tags[0]||"unsorted"),n=0;r.forEach((l,m)=>{n>0&&console.log();let c=(_process2.default.stdout.columns-16-m.length)/2,p=c>0?Array.from({length:c}).fill(" ").join(""):"";console.log(p+_chalk2.default.bold.underline(m)),u(l,t).forEach(h=>{console.log(h)}),n+=1})}console.log(`
|
|
2
|
+
Listed ${_chalk2.default.greenBright(String(s.length))} HTTP ${s.length===1?"route":"routes"}.
|
|
3
|
+
`)},F= exports.listCommand =N;exports.listCommand = F;
|
|
203
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/next/cli/list/list-command.ts","../../../src/next/cli/list/api-route-file-parser.ts","../../../src/next/cli/list/collect-api-route-files.ts","../../../src/next/cli/list/routes-render.ts"],"names":["colors","join","process","fs"],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\nimport { join } from \"node:path\";\nimport process from \"node:process\";\n\nimport apiRouteFileParser from \"./api-route-file-parser\";\nimport collectApiRouteFiles from \"./collect-api-route-files\";\nimport routesRender from \"./routes-render\";\nimport type { Route } from \"./types\";\n\ntype RenderOptions = {\n includePaths: string[];\n excludePaths: string[];\n methods: string[];\n group: string;\n};\n\nconst groupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map();\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\nconst listCommand = async (\n path: string = \"\",\n options: Partial<\n {\n verbose: boolean;\n } & RenderOptions\n > = {},\n// eslint-disable-next-line radar/cognitive-complexity\n) => {\n const routePath = join(process.cwd(), path);\n\n const apiRouteFiles = await collectApiRouteFiles(routePath, options.verbose || false);\n\n if (apiRouteFiles.length === 0) {\n // eslint-disable-next-line no-console\n console.error(`No API routes found, in \"${routePath}\".`);\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1);\n }\n\n let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, routePath, options.verbose || false));\n\n if (options.includePaths) {\n parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));\n }\n\n if (options.excludePaths) {\n parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));\n }\n\n if (options.group === undefined) {\n routesRender([], options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n } else {\n const groupedMap = groupBy(parsedApiRoutes, (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((routes, 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 // eslint-disable-next-line no-console\n console.log(dots + colors.bold.underline(key));\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n }\n // });\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${colors.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n","import type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport fs from \"node:fs\";\nimport process from \"node:process\";\n\nimport type { Route } from \"./types\";\n\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwdPath: string, verbose: boolean = false): Route[] => {\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 = fs.readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/).forEach((line) => {\n const match = line.match(/[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n method: method as string,\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\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 path, method: method.toUpperCase(), tags: methodSpec.tags, file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/readdir\";\nimport fs from \"node:fs\";\nimport { join } from \"node:path\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return fs.statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path: string = \"\", verbose: boolean = false): 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: [\".js\", \".cjs\", \".mjs\", \".ts\"],\n includeDirs: false,\n minimatchOptions: {\n match: {\n debug: verbose,\n matchBase: true,\n },\n skip: {\n debug: verbose,\n matchBase: true,\n },\n },\n });\n};\n\nexport default collectApiRouteFiles;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n GET: colors.blue,\n POST: colors.yellow,\n PATCH: colors.yellow,\n PUT: colors.yellow,\n DELETE: colors.redBright,\n OPTIONS: colors.hex(\"#6C7280\"),\n ANY: colors.redBright,\n HEAD: colors.hex(\"#6C7280\"),\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${colors.blue(\"GET\")}${colors.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${colors.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 ? colors.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${colors.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[]; } = {}) => routesMap\n .map((route) => {\n if (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"]}
|
|
1
|
+
{"version":3,"sources":["../../../src/next/cli/list/list-command.ts","../../../src/next/cli/list/api-route-file-parser.ts","../../../src/next/cli/list/collect-api-route-files.ts","../../../src/next/cli/list/routes-render.ts"],"names":["colors","join","process","jsDocumentCommentsToOpenApi","parseFile","swaggerJsDocumentCommentsToOpenApi","fs","extensionRegex","apiRouteFileParser","apiRouteFile","cwdPath","verbose","specs","parsedJsDocumentFile","item","parsedSwaggerJsDocumentFile","routes","line","match","method","spec","path","pathSpec","methodSpec","api_route_file_parser_default","collect","isDirectory","collectApiRouteFiles","apiFolderPath","collect_api_route_files_default","renderRoute","routePath","colorMap","methodText","coloredMethod","spacesCount","spaces","dotsCount","dots","routeText","segment","routesRender","routesMap","options","route","routes_render_default","groupBy","list","keyGetter","map","key","collection","listCommand","apiRouteFiles","parsedApiRoutes","ipath","epath","renderedRoute","groupedMap","counter","list_command_default"],"mappings":"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","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\nimport { join } from \"node:path\";\nimport process from \"node:process\";\n\nimport apiRouteFileParser from \"./api-route-file-parser\";\nimport collectApiRouteFiles from \"./collect-api-route-files\";\nimport routesRender from \"./routes-render\";\nimport type { Route } from \"./types\";\n\ntype RenderOptions = {\n includePaths: string[];\n excludePaths: string[];\n methods: string[];\n group: string;\n};\n\nconst groupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map();\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\nconst listCommand = async (\n path: string = \"\",\n options: Partial<\n {\n verbose: boolean;\n } & RenderOptions\n > = {},\n// eslint-disable-next-line radar/cognitive-complexity\n) => {\n const routePath = join(process.cwd(), path);\n\n const apiRouteFiles = await collectApiRouteFiles(routePath, options.verbose || false);\n\n if (apiRouteFiles.length === 0) {\n // eslint-disable-next-line no-console\n console.error(`No API routes found, in \"${routePath}\".`);\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1);\n }\n\n let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, routePath, options.verbose || false));\n\n if (options.includePaths) {\n parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));\n }\n\n if (options.excludePaths) {\n parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));\n }\n\n if (options.group === undefined) {\n routesRender([], options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n } else {\n const groupedMap = groupBy(parsedApiRoutes, (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((routes, 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 // eslint-disable-next-line no-console\n console.log(dots + colors.bold.underline(key));\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n }\n // });\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${colors.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n","import type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport fs from \"node:fs\";\nimport process from \"node:process\";\n\nimport type { Route } from \"./types\";\n\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwdPath: string, verbose: boolean = false): Route[] => {\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 = fs.readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/).forEach((line) => {\n const match = line.match(/[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n method: method as string,\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\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 path, method: method.toUpperCase(), tags: methodSpec.tags, file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/readdir\";\nimport fs from \"node:fs\";\nimport { join } from \"node:path\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return fs.statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path: string = \"\", verbose: boolean = false): 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: [\".js\", \".cjs\", \".mjs\", \".ts\"],\n includeDirs: false,\n minimatchOptions: {\n match: {\n debug: verbose,\n matchBase: true,\n },\n skip: {\n debug: verbose,\n matchBase: true,\n },\n },\n });\n};\n\nexport default collectApiRouteFiles;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n GET: colors.blue,\n POST: colors.yellow,\n PATCH: colors.yellow,\n PUT: colors.yellow,\n DELETE: colors.redBright,\n OPTIONS: colors.hex(\"#6C7280\"),\n ANY: colors.redBright,\n HEAD: colors.hex(\"#6C7280\"),\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${colors.blue(\"GET\")}${colors.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${colors.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 ? colors.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${colors.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[]; } = {}) => routesMap\n .map((route) => {\n if (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"]}
|
package/dist/next/cli/index.mjs
CHANGED
|
@@ -1,203 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import colors2 from "chalk";
|
|
5
|
-
import { join as join2 } from "path";
|
|
6
|
-
import process3 from "process";
|
|
7
|
-
|
|
8
|
-
// src/next/cli/list/api-route-file-parser.ts
|
|
9
|
-
import { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from "@visulima/jsdoc-open-api";
|
|
10
|
-
import fs from "fs";
|
|
11
|
-
import process2 from "process";
|
|
12
|
-
var extensionRegex = /\.(js|ts|mjs|cjs)$/;
|
|
13
|
-
var apiRouteFileParser = (apiRouteFile, cwdPath, verbose = false) => {
|
|
14
|
-
let specs = [];
|
|
15
|
-
const parsedJsDocumentFile = parseFile(apiRouteFile, jsDocumentCommentsToOpenApi, verbose);
|
|
16
|
-
specs = [...specs, ...parsedJsDocumentFile.map((item) => item.spec)];
|
|
17
|
-
const parsedSwaggerJsDocumentFile = parseFile(apiRouteFile, swaggerJsDocumentCommentsToOpenApi, verbose);
|
|
18
|
-
specs = [...specs, ...parsedSwaggerJsDocumentFile.map((item) => item.spec)];
|
|
19
|
-
const routes = [];
|
|
20
|
-
if (specs.length === 0) {
|
|
21
|
-
const apiRouteFileContent = fs.readFileSync(apiRouteFile, "utf8");
|
|
22
|
-
apiRouteFileContent.split(/\r?\n/).forEach((line) => {
|
|
23
|
-
const match = line.match(/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/);
|
|
24
|
-
if (match) {
|
|
25
|
-
let [, method] = match;
|
|
26
|
-
if (method === "GET") {
|
|
27
|
-
method = "GET|HEAD";
|
|
28
|
-
}
|
|
29
|
-
routes.push({
|
|
30
|
-
method,
|
|
31
|
-
path: apiRouteFile.replace(cwdPath, "").replace(extensionRegex, ""),
|
|
32
|
-
tags: [],
|
|
33
|
-
file: apiRouteFile.replace(`${process2.cwd()}/`, "")
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
if (routes.length === 0) {
|
|
38
|
-
routes.push({
|
|
39
|
-
method: "GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",
|
|
40
|
-
path: apiRouteFile.replace(cwdPath, "").replace(extensionRegex, ""),
|
|
41
|
-
tags: [],
|
|
42
|
-
file: apiRouteFile.replace(`${process2.cwd()}/`, "")
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
return routes;
|
|
46
|
-
}
|
|
47
|
-
specs.forEach((spec) => {
|
|
48
|
-
const paths = Object.entries(spec.paths);
|
|
49
|
-
paths.forEach(([path, pathSpec]) => {
|
|
50
|
-
const methods = Object.entries(pathSpec);
|
|
51
|
-
methods.forEach(([method, methodSpec]) => {
|
|
52
|
-
routes.push({
|
|
53
|
-
path,
|
|
54
|
-
method: method.toUpperCase(),
|
|
55
|
-
tags: methodSpec.tags,
|
|
56
|
-
file: apiRouteFile.replace(`${process2.cwd()}/`, "")
|
|
57
|
-
});
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
return routes;
|
|
62
|
-
};
|
|
63
|
-
var api_route_file_parser_default = apiRouteFileParser;
|
|
64
|
-
|
|
65
|
-
// src/next/cli/list/collect-api-route-files.ts
|
|
66
|
-
import { collect } from "@visulima/readdir";
|
|
67
|
-
import fs2 from "fs";
|
|
68
|
-
import { join } from "path";
|
|
69
|
-
var isDirectory = (path) => {
|
|
70
|
-
try {
|
|
71
|
-
return fs2.statSync(path).isDirectory();
|
|
72
|
-
} catch {
|
|
73
|
-
return false;
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
var collectApiRouteFiles = async (path = "", verbose = false) => {
|
|
77
|
-
let apiFolderPath = join(path, "pages/api");
|
|
78
|
-
if (!isDirectory(apiFolderPath)) {
|
|
79
|
-
apiFolderPath = join(path, "src/pages/api");
|
|
80
|
-
if (!isDirectory(apiFolderPath)) {
|
|
81
|
-
return [];
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
return collect(apiFolderPath, {
|
|
85
|
-
extensions: [".js", ".cjs", ".mjs", ".ts"],
|
|
86
|
-
includeDirs: false,
|
|
87
|
-
minimatchOptions: {
|
|
88
|
-
match: {
|
|
89
|
-
debug: verbose,
|
|
90
|
-
matchBase: true
|
|
91
|
-
},
|
|
92
|
-
skip: {
|
|
93
|
-
debug: verbose,
|
|
94
|
-
matchBase: true
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
};
|
|
99
|
-
var collect_api_route_files_default = collectApiRouteFiles;
|
|
100
|
-
|
|
101
|
-
// src/next/cli/list/routes-render.ts
|
|
102
|
-
import colors from "chalk";
|
|
103
|
-
var renderRoute = (method, routePath) => {
|
|
104
|
-
const colorMap = {
|
|
105
|
-
GET: colors.blue,
|
|
106
|
-
POST: colors.yellow,
|
|
107
|
-
PATCH: colors.yellow,
|
|
108
|
-
PUT: colors.yellow,
|
|
109
|
-
DELETE: colors.redBright,
|
|
110
|
-
OPTIONS: colors.hex("#6C7280"),
|
|
111
|
-
ANY: colors.redBright,
|
|
112
|
-
HEAD: colors.hex("#6C7280")
|
|
113
|
-
};
|
|
114
|
-
let methodText;
|
|
115
|
-
if (method === "GET|HEAD") {
|
|
116
|
-
methodText = `${colors.blue("GET")}${colors.grey("|HEAD")}`;
|
|
117
|
-
} else {
|
|
118
|
-
const coloredMethod = colorMap[method](method);
|
|
119
|
-
methodText = method === "GET" ? `${coloredMethod}${colors.grey("|HEAD")}` : coloredMethod;
|
|
120
|
-
}
|
|
121
|
-
const spacesCount = method === "GET" ? 6 : 14 - method.length;
|
|
122
|
-
const spaces = Array.from({ length: spacesCount }).fill(" ").join("");
|
|
123
|
-
const dotsCount = process.stdout.columns - 16 - routePath.length - 4;
|
|
124
|
-
const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(".").join("") : "";
|
|
125
|
-
const routeText = routePath.split("/").map((segment) => {
|
|
126
|
-
const isDynamicSegment = ["[", ":"].includes(segment[0] || "");
|
|
127
|
-
return isDynamicSegment ? colors.yellowBright(segment) : segment;
|
|
128
|
-
}).join("/");
|
|
129
|
-
return ` ${methodText}${spaces}${routeText}${colors.grey(dots)}`;
|
|
130
|
-
};
|
|
131
|
-
var routesRender = (routesMap, options = {}) => routesMap.map((route) => {
|
|
132
|
-
if (options.methods && options.methods.includes(route.method)) {
|
|
133
|
-
return;
|
|
134
|
-
}
|
|
135
|
-
if (route.method === "GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS") {
|
|
136
|
-
route.method = "ANY";
|
|
137
|
-
}
|
|
138
|
-
return renderRoute(route.method, route.path.replace("/pages", ""));
|
|
139
|
-
}).filter(Boolean);
|
|
140
|
-
var routes_render_default = routesRender;
|
|
141
|
-
|
|
142
|
-
// src/next/cli/list/list-command.ts
|
|
143
|
-
var groupBy = (list, keyGetter) => {
|
|
144
|
-
const map = /* @__PURE__ */ new Map();
|
|
145
|
-
list.forEach((item) => {
|
|
146
|
-
const key = keyGetter(item);
|
|
147
|
-
const collection = map.get(key);
|
|
148
|
-
if (collection) {
|
|
149
|
-
collection.push(item);
|
|
150
|
-
} else {
|
|
151
|
-
map.set(key, [item]);
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
return map;
|
|
155
|
-
};
|
|
156
|
-
var listCommand = async (path = "", options = {}) => {
|
|
157
|
-
const routePath = join2(process3.cwd(), path);
|
|
158
|
-
const apiRouteFiles = await collect_api_route_files_default(routePath, options.verbose || false);
|
|
159
|
-
if (apiRouteFiles.length === 0) {
|
|
160
|
-
console.error(`No API routes found, in "${routePath}".`);
|
|
161
|
-
process3.exit(1);
|
|
162
|
-
}
|
|
163
|
-
let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => api_route_file_parser_default(apiRouteFile, routePath, options.verbose || false));
|
|
164
|
-
if (options.includePaths) {
|
|
165
|
-
parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));
|
|
166
|
-
}
|
|
167
|
-
if (options.excludePaths) {
|
|
168
|
-
parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));
|
|
169
|
-
}
|
|
170
|
-
if (options.group === void 0) {
|
|
171
|
-
routes_render_default([], options).forEach((renderedRoute) => {
|
|
172
|
-
console.log(renderedRoute);
|
|
173
|
-
});
|
|
174
|
-
} else {
|
|
175
|
-
const groupedMap = groupBy(parsedApiRoutes, (route) => {
|
|
176
|
-
if (options.group === "path") {
|
|
177
|
-
return route.path.replace("/pages", "").split("/")[1];
|
|
178
|
-
}
|
|
179
|
-
return route.tags[0] || "unsorted";
|
|
180
|
-
});
|
|
181
|
-
let counter = 0;
|
|
182
|
-
groupedMap.forEach((routes, key) => {
|
|
183
|
-
if (counter > 0) {
|
|
184
|
-
console.log();
|
|
185
|
-
}
|
|
186
|
-
const dotsCount = (process3.stdout.columns - 16 - key.length) / 2;
|
|
187
|
-
const dots = dotsCount > 0 ? Array.from({ length: dotsCount }).fill(" ").join("") : "";
|
|
188
|
-
console.log(dots + colors2.bold.underline(key));
|
|
189
|
-
routes_render_default(routes, options).forEach((renderedRoute) => {
|
|
190
|
-
console.log(renderedRoute);
|
|
191
|
-
});
|
|
192
|
-
counter += 1;
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
console.log(`
|
|
196
|
-
Listed ${colors2.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? "route" : "routes"}.
|
|
197
|
-
`);
|
|
198
|
-
};
|
|
199
|
-
var list_command_default = listCommand;
|
|
200
|
-
export {
|
|
201
|
-
list_command_default as listCommand
|
|
202
|
-
};
|
|
1
|
+
import"../../chunk-YOXCJZNX.mjs";import O from"chalk";import{join as M}from"path";import g from"process";import{jsDocumentCommentsToOpenApi as R,parseFile as d,swaggerJsDocumentCommentsToOpenApi as x}from"@visulima/jsdoc-open-api";import C from"fs";import f from"process";var E=/\.(js|ts|mjs|cjs)$/,$=(e,t,o=!1)=>{let s=[],i=d(e,R,o);s=[...s,...i.map(l=>l.spec)];let r=d(e,x,o);s=[...s,...r.map(l=>l.spec)];let n=[];return s.length===0?(C.readFileSync(e,"utf8").split(/\r?\n/).forEach(m=>{let c=m.match(/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/);if(c){let[,p]=c;p==="GET"&&(p="GET|HEAD"),n.push({method:p,path:e.replace(t,"").replace(E,""),tags:[],file:e.replace(`${f.cwd()}/`,"")})}}),n.length===0&&n.push({method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:e.replace(t,"").replace(E,""),tags:[],file:e.replace(`${f.cwd()}/`,"")}),n):(s.forEach(l=>{Object.entries(l.paths).forEach(([c,p])=>{Object.entries(p).forEach(([D,j])=>{n.push({path:c,method:D.toUpperCase(),tags:j.tags,file:e.replace(`${f.cwd()}/`,"")})})})}),n)},T=$;import{collect as b}from"@visulima/readdir";import S from"fs";import{join as y}from"path";var P=e=>{try{return S.statSync(e).isDirectory()}catch{return!1}},H=async(e="",t=!1)=>{let o=y(e,"pages/api");return!P(o)&&(o=y(e,"src/pages/api"),!P(o))?[]:b(o,{extensions:[".js",".cjs",".mjs",".ts"],includeDirs:!1,minimatchOptions:{match:{debug:t,matchBase:!0},skip:{debug:t,matchBase:!0}}})},A=H;import a from"chalk";var w=(e,t)=>{let o={GET:a.blue,POST:a.yellow,PATCH:a.yellow,PUT:a.yellow,DELETE:a.redBright,OPTIONS:a.hex("#6C7280"),ANY:a.redBright,HEAD:a.hex("#6C7280")},s;if(e==="GET|HEAD")s=`${a.blue("GET")}${a.grey("|HEAD")}`;else{let c=o[e](e);s=e==="GET"?`${c}${a.grey("|HEAD")}`:c}let i=e==="GET"?6:14-e.length,r=Array.from({length:i}).fill(" ").join(""),n=process.stdout.columns-16-t.length-4,l=n>0?Array.from({length:n}).fill(".").join(""):"",m=t.split("/").map(c=>["[",":"].includes(c[0]||"")?a.yellowBright(c):c).join("/");return` ${s}${r}${m}${a.grey(l)}`},G=(e,t={})=>e.map(o=>{if(!(t.methods&&t.methods.includes(o.method)))return o.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(o.method="ANY"),w(o.method,o.path.replace("/pages",""))}).filter(Boolean),u=G;var B=(e,t)=>{let o=new Map;return e.forEach(s=>{let i=t(s),r=o.get(i);r?r.push(s):o.set(i,[s])}),o},N=async(e="",t={})=>{let o=M(g.cwd(),e),s=await A(o,t.verbose||!1);s.length===0&&(console.error(`No API routes found, in "${o}".`),g.exit(1));let i=s.flatMap(r=>T(r,o,t.verbose||!1));if(t.includePaths&&(i=t.includePaths.flatMap(r=>i.filter(n=>n.path.startsWith(r)))),t.excludePaths&&(i=t.excludePaths.flatMap(r=>i.filter(n=>!n.path.startsWith(r)))),t.group===void 0)u([],t).forEach(r=>{console.log(r)});else{let r=B(i,l=>t.group==="path"?l.path.replace("/pages","").split("/")[1]:l.tags[0]||"unsorted"),n=0;r.forEach((l,m)=>{n>0&&console.log();let c=(g.stdout.columns-16-m.length)/2,p=c>0?Array.from({length:c}).fill(" ").join(""):"";console.log(p+O.bold.underline(m)),u(l,t).forEach(h=>{console.log(h)}),n+=1})}console.log(`
|
|
2
|
+
Listed ${O.greenBright(String(s.length))} HTTP ${s.length===1?"route":"routes"}.
|
|
3
|
+
`)},F=N;export{F as listCommand};
|
|
203
4
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/next/cli/list/list-command.ts","../../../src/next/cli/list/api-route-file-parser.ts","../../../src/next/cli/list/collect-api-route-files.ts","../../../src/next/cli/list/routes-render.ts"],"sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\nimport { join } from \"node:path\";\nimport process from \"node:process\";\n\nimport apiRouteFileParser from \"./api-route-file-parser\";\nimport collectApiRouteFiles from \"./collect-api-route-files\";\nimport routesRender from \"./routes-render\";\nimport type { Route } from \"./types\";\n\ntype RenderOptions = {\n includePaths: string[];\n excludePaths: string[];\n methods: string[];\n group: string;\n};\n\nconst groupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map();\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\nconst listCommand = async (\n path: string = \"\",\n options: Partial<\n {\n verbose: boolean;\n } & RenderOptions\n > = {},\n// eslint-disable-next-line radar/cognitive-complexity\n) => {\n const routePath = join(process.cwd(), path);\n\n const apiRouteFiles = await collectApiRouteFiles(routePath, options.verbose || false);\n\n if (apiRouteFiles.length === 0) {\n // eslint-disable-next-line no-console\n console.error(`No API routes found, in \"${routePath}\".`);\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1);\n }\n\n let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, routePath, options.verbose || false));\n\n if (options.includePaths) {\n parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));\n }\n\n if (options.excludePaths) {\n parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));\n }\n\n if (options.group === undefined) {\n routesRender([], options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n } else {\n const groupedMap = groupBy(parsedApiRoutes, (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((routes, 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 // eslint-disable-next-line no-console\n console.log(dots + colors.bold.underline(key));\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n }\n // });\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${colors.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n","import type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport fs from \"node:fs\";\nimport process from \"node:process\";\n\nimport type { Route } from \"./types\";\n\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwdPath: string, verbose: boolean = false): Route[] => {\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 = fs.readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/).forEach((line) => {\n const match = line.match(/[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n method: method as string,\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\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 path, method: method.toUpperCase(), tags: methodSpec.tags, file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/readdir\";\nimport fs from \"node:fs\";\nimport { join } from \"node:path\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return fs.statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path: string = \"\", verbose: boolean = false): 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: [\".js\", \".cjs\", \".mjs\", \".ts\"],\n includeDirs: false,\n minimatchOptions: {\n match: {\n debug: verbose,\n matchBase: true,\n },\n skip: {\n debug: verbose,\n matchBase: true,\n },\n },\n });\n};\n\nexport default collectApiRouteFiles;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n GET: colors.blue,\n POST: colors.yellow,\n PATCH: colors.yellow,\n PUT: colors.yellow,\n DELETE: colors.redBright,\n OPTIONS: colors.hex(\"#6C7280\"),\n ANY: colors.redBright,\n HEAD: colors.hex(\"#6C7280\"),\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${colors.blue(\"GET\")}${colors.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${colors.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 ? colors.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${colors.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[]; } = {}) => routesMap\n .map((route) => {\n if (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"],"mappings":"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","names":["colors","join","process","process","fs","join","process","colors"]}
|
|
1
|
+
{"version":3,"sources":["../../../src/next/cli/list/list-command.ts","../../../src/next/cli/list/api-route-file-parser.ts","../../../src/next/cli/list/collect-api-route-files.ts","../../../src/next/cli/list/routes-render.ts"],"sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\nimport { join } from \"node:path\";\nimport process from \"node:process\";\n\nimport apiRouteFileParser from \"./api-route-file-parser\";\nimport collectApiRouteFiles from \"./collect-api-route-files\";\nimport routesRender from \"./routes-render\";\nimport type { Route } from \"./types\";\n\ntype RenderOptions = {\n includePaths: string[];\n excludePaths: string[];\n methods: string[];\n group: string;\n};\n\nconst groupBy = (list: Route[], keyGetter: (item: Route) => keyof Route): Map<string, Route[]> => {\n const map = new Map();\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\nconst listCommand = async (\n path: string = \"\",\n options: Partial<\n {\n verbose: boolean;\n } & RenderOptions\n > = {},\n// eslint-disable-next-line radar/cognitive-complexity\n) => {\n const routePath = join(process.cwd(), path);\n\n const apiRouteFiles = await collectApiRouteFiles(routePath, options.verbose || false);\n\n if (apiRouteFiles.length === 0) {\n // eslint-disable-next-line no-console\n console.error(`No API routes found, in \"${routePath}\".`);\n // eslint-disable-next-line unicorn/no-process-exit\n process.exit(1);\n }\n\n let parsedApiRoutes = apiRouteFiles.flatMap((apiRouteFile) => apiRouteFileParser(apiRouteFile, routePath, options.verbose || false));\n\n if (options.includePaths) {\n parsedApiRoutes = options.includePaths.flatMap((ipath) => parsedApiRoutes.filter((route) => route.path.startsWith(ipath)));\n }\n\n if (options.excludePaths) {\n parsedApiRoutes = options.excludePaths.flatMap((epath) => parsedApiRoutes.filter((route) => !route.path.startsWith(epath)));\n }\n\n if (options.group === undefined) {\n routesRender([], options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n } else {\n const groupedMap = groupBy(parsedApiRoutes, (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((routes, 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 // eslint-disable-next-line no-console\n console.log(dots + colors.bold.underline(key));\n\n routesRender(routes, options).forEach((renderedRoute) => {\n // eslint-disable-next-line no-console\n console.log(renderedRoute);\n });\n\n counter += 1;\n });\n }\n // });\n\n // eslint-disable-next-line no-console\n console.log(`\\n Listed ${colors.greenBright(String(apiRouteFiles.length))} HTTP ${apiRouteFiles.length === 1 ? \"route\" : \"routes\"}.\\n`);\n};\n\nexport default listCommand;\n","import type { OpenApiObject } from \"@visulima/jsdoc-open-api\";\nimport { jsDocumentCommentsToOpenApi, parseFile, swaggerJsDocumentCommentsToOpenApi } from \"@visulima/jsdoc-open-api\";\nimport fs from \"node:fs\";\nimport process from \"node:process\";\n\nimport type { Route } from \"./types\";\n\nconst extensionRegex = /\\.(js|ts|mjs|cjs)$/;\n\nconst apiRouteFileParser = (apiRouteFile: string, cwdPath: string, verbose: boolean = false): Route[] => {\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 = fs.readFileSync(apiRouteFile, \"utf8\");\n\n apiRouteFileContent.split(/\\r?\\n/).forEach((line) => {\n const match = line.match(/[=aces|]+\\s[\"'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)[\"'|]/);\n\n if (match) {\n let [, method] = match;\n\n if (method === \"GET\") {\n method = \"GET|HEAD\";\n }\n\n routes.push({\n method: method as string,\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n }\n });\n\n if (routes.length === 0) {\n routes.push({\n method: \"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS\",\n path: apiRouteFile.replace(cwdPath, \"\").replace(extensionRegex, \"\"),\n tags: [],\n file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\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 path, method: method.toUpperCase(), tags: methodSpec.tags, file: apiRouteFile.replace(`${process.cwd()}/`, \"\"),\n });\n });\n });\n });\n\n return routes;\n};\n\nexport default apiRouteFileParser;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport { collect } from \"@visulima/readdir\";\nimport fs from \"node:fs\";\nimport { join } from \"node:path\";\n\nconst isDirectory = (path: string): boolean => {\n try {\n return fs.statSync(path).isDirectory();\n } catch {\n return false;\n }\n};\n\nconst collectApiRouteFiles = async (path: string = \"\", verbose: boolean = false): 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: [\".js\", \".cjs\", \".mjs\", \".ts\"],\n includeDirs: false,\n minimatchOptions: {\n match: {\n debug: verbose,\n matchBase: true,\n },\n skip: {\n debug: verbose,\n matchBase: true,\n },\n },\n });\n};\n\nexport default collectApiRouteFiles;\n","// eslint-disable-next-line import/no-extraneous-dependencies\nimport colors from \"chalk\";\n\nimport type { Route } from \"./types\";\n\nconst renderRoute = (method: string, routePath: string): string => {\n const colorMap = {\n GET: colors.blue,\n POST: colors.yellow,\n PATCH: colors.yellow,\n PUT: colors.yellow,\n DELETE: colors.redBright,\n OPTIONS: colors.hex(\"#6C7280\"),\n ANY: colors.redBright,\n HEAD: colors.hex(\"#6C7280\"),\n };\n\n let methodText: string;\n\n if (method === \"GET|HEAD\") {\n methodText = `${colors.blue(\"GET\")}${colors.grey(\"|HEAD\")}`;\n } else {\n const coloredMethod = colorMap[method as keyof typeof colorMap](method);\n\n methodText = method === \"GET\" ? `${coloredMethod}${colors.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 ? colors.yellowBright(segment) : segment;\n })\n .join(\"/\");\n\n return ` ${methodText}${spaces}${routeText}${colors.grey(dots)}`;\n};\n\nconst routesRender = (routesMap: Route[], options: { methods?: string[]; } = {}) => routesMap\n .map((route) => {\n if (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"],"mappings":"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","names":["colors","join","process","jsDocumentCommentsToOpenApi","parseFile","swaggerJsDocumentCommentsToOpenApi","fs","process","extensionRegex","apiRouteFileParser","apiRouteFile","cwdPath","verbose","specs","parsedJsDocumentFile","item","parsedSwaggerJsDocumentFile","routes","line","match","method","spec","path","pathSpec","methodSpec","api_route_file_parser_default","collect","fs","join","isDirectory","path","collectApiRouteFiles","verbose","apiFolderPath","collect_api_route_files_default","colors","renderRoute","method","routePath","colorMap","methodText","coloredMethod","spacesCount","spaces","dotsCount","dots","routeText","segment","routesRender","routesMap","options","route","routes_render_default","groupBy","list","keyGetter","map","item","key","collection","listCommand","path","options","routePath","join","process","apiRouteFiles","collect_api_route_files_default","parsedApiRoutes","apiRouteFile","api_route_file_parser_default","ipath","route","epath","routes_render_default","renderedRoute","groupedMap","counter","routes","dotsCount","dots","colors","list_command_default"]}
|
|
@@ -1,12 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var _chunkCVURPKKGjs = require('../chunk-CVURPKKG.js');
|
|
6
|
-
require('../chunk-JC4IRQUL.js');
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
exports.RedocPage = _chunkCVURPKKGjs.redoc_default; exports.SwaggerPage = _chunkCVURPKKGjs.swagger_default; exports.getSwaggerStaticProps = _chunkCVURPKKGjs.get_static_properties_swagger_default;
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _chunkUI23SSBNjs = require('../chunk-UI23SSBN.js');require('../chunk-OUWZ2PU5.js');exports.RedocPage = _chunkUI23SSBNjs.a; exports.SwaggerPage = _chunkUI23SSBNjs.b; exports.getSwaggerStaticProps = _chunkUI23SSBNjs.c;
|
|
12
2
|
//# sourceMappingURL=index-browser.js.map
|
|
@@ -1,12 +1,2 @@
|
|
|
1
|
-
import
|
|
2
|
-
get_static_properties_swagger_default,
|
|
3
|
-
redoc_default,
|
|
4
|
-
swagger_default
|
|
5
|
-
} from "../chunk-EGE7A4ZK.mjs";
|
|
6
|
-
import "../chunk-5VRACIDE.mjs";
|
|
7
|
-
export {
|
|
8
|
-
redoc_default as RedocPage,
|
|
9
|
-
swagger_default as SwaggerPage,
|
|
10
|
-
get_static_properties_swagger_default as getSwaggerStaticProps
|
|
11
|
-
};
|
|
1
|
+
import{a,b,c}from"../chunk-M7LGAQP3.mjs";import"../chunk-YOXCJZNX.mjs";export{a as RedocPage,b as SwaggerPage,c as getSwaggerStaticProps};
|
|
12
2
|
//# sourceMappingURL=index-browser.mjs.map
|