@majkapp/plugin-kit 1.0.11 → 1.0.13
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/dist/plugin-kit.d.ts.map +1 -1
- package/dist/plugin-kit.js +19 -5
- package/package.json +1 -1
package/dist/plugin-kit.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin-kit.d.ts","sourceRoot":"","sources":["../src/plugin-kit.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,aAAa,EAGb,eAAe,EACf,QAAQ,EACR,WAAW,EACX,WAAW,EACX,QAAQ,EACR,WAAW,EACX,UAAU,EACV,eAAe,EACf,WAAW,EACX,KAAK,EACL,UAAU,EACV,SAAS,EACT,aAAa,EAIb,eAAe,EACf,gBAAgB,EACjB,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"plugin-kit.d.ts","sourceRoot":"","sources":["../src/plugin-kit.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,aAAa,EAGb,eAAe,EACf,QAAQ,EACR,WAAW,EACX,WAAW,EACX,QAAQ,EACR,WAAW,EACX,UAAU,EACV,eAAe,EACf,WAAW,EACX,KAAK,EACL,UAAU,EACV,SAAS,EACT,aAAa,EAIb,eAAe,EACf,gBAAgB,EACjB,MAAM,SAAS,CAAC;AA4tBjB;;GAEG;AACH,MAAM,WAAW,aAAa,CAAC,EAAE,SAAS,MAAM;IAC9C,mDAAmD;IACnD,MAAM,CAAC,KAAK,EAAE,mBAAmB,EAAE,IAAI,MAAM,EAAE,EAAE,IAAI,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAE7G,0CAA0C;IAC1C,EAAE,CAAC,MAAM,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC;IAE5B,yBAAyB;IACzB,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;IAE3C,yBAAyB;IACzB,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;IAEzC,uBAAuB;IACvB,QAAQ,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI,CAAC;IAEnC,iBAAiB;IACjB,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,GAAG,IAAI,CAAC;IAE/D,oEAAoE;IACpE,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;IAEtD,8DAA8D;IAC9D,SAAS,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC;IAE5C,+DAA+D;IAC/D,UAAU,CAAC,OAAO,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC;IAE9C,wBAAwB;IACxB,YAAY,CAAC,GAAG,EAAE,eAAe,GAAG,IAAI,CAAC;IAEzC,0BAA0B;IAC1B,QAAQ,CAAC,GAAG,EAAE,WAAW,GAAG,IAAI,CAAC;IAEjC,sCAAsC;IACtC,OAAO,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC,EAAE,EAAE,SAAS,KAAK,IAAI,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAElG,0BAA0B;IAC1B,MAAM,CAAC,EAAE,EAAE,aAAa,GAAG,IAAI,CAAC;IAEhC;;;;;;;;;;OAUG;IACH,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IAE9B,uBAAuB;IACvB,KAAK,IAAI,eAAe,CAAC;CAC1B;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,KAAK,CAAC,EAAE,SAAS,MAAM,EAClD,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,GACd,aAAa,CAAC,EAAE,CAAC,CA4WnB"}
|
package/dist/plugin-kit.js
CHANGED
|
@@ -152,13 +152,21 @@ function validateEntity(entityType, entity) {
|
|
|
152
152
|
*/
|
|
153
153
|
function pathToRegex(p) {
|
|
154
154
|
const keys = [];
|
|
155
|
-
|
|
156
|
-
|
|
155
|
+
console.log(`[pathToRegex] Input path: ${p}`);
|
|
156
|
+
// First, escape special regex characters EXCEPT the colon (for path params)
|
|
157
|
+
const escaped = p.replace(/([.+*?=^!${}()[\]|\\])/g, '\\$1');
|
|
158
|
+
console.log(`[pathToRegex] After escaping: ${escaped}`);
|
|
159
|
+
// Then, replace path parameters with capturing groups
|
|
160
|
+
const pattern = escaped.replace(/\/:([A-Za-z0-9_]+)/g, (_m, k) => {
|
|
157
161
|
keys.push(k);
|
|
162
|
+
console.log(`[pathToRegex] Found param: ${k}`);
|
|
158
163
|
return '/([^/]+)';
|
|
159
|
-
})
|
|
160
|
-
|
|
161
|
-
|
|
164
|
+
});
|
|
165
|
+
console.log(`[pathToRegex] Final pattern: ${pattern}`);
|
|
166
|
+
console.log(`[pathToRegex] Keys: [${keys.join(', ')}]`);
|
|
167
|
+
const regex = new RegExp(`^${pattern}$`);
|
|
168
|
+
console.log(`[pathToRegex] Final regex: ${regex}`);
|
|
169
|
+
return { regex, keys };
|
|
162
170
|
}
|
|
163
171
|
/**
|
|
164
172
|
* CORS headers
|
|
@@ -527,6 +535,12 @@ class BuiltPlugin {
|
|
|
527
535
|
const url = new URL(req.url, `http://localhost:${port}`);
|
|
528
536
|
const pathname = url.pathname;
|
|
529
537
|
const method = req.method;
|
|
538
|
+
this.context.logger.info(`[ROUTE MATCHING] Incoming: ${method} ${pathname}`);
|
|
539
|
+
this.context.logger.info(`[ROUTE MATCHING] Available routes: ${this.router.length}`);
|
|
540
|
+
this.router.forEach((r, idx) => {
|
|
541
|
+
const matches = r.regex.test(pathname);
|
|
542
|
+
this.context.logger.info(`[ROUTE MATCHING] Route ${idx}: ${r.method} ${r.name} - regex: ${r.regex} - keys: [${r.keys.join(', ')}] - matches: ${matches}`);
|
|
543
|
+
});
|
|
530
544
|
const route = this.router.find(r => r.method === method && r.regex.test(pathname));
|
|
531
545
|
if (!route) {
|
|
532
546
|
res.writeHead(404, corsHeaders({ 'Content-Type': 'application/json' }));
|