cahita 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/LICENCE +22 -0
  2. package/README.md +0 -0
  3. package/dist/helpers/augment-response.helper.d.ts +4 -0
  4. package/dist/helpers/augment-response.helper.d.ts.map +1 -0
  5. package/dist/helpers/augment-response.helper.js +40 -0
  6. package/dist/helpers/augment-response.helper.js.map +1 -0
  7. package/dist/index.d.ts +10 -0
  8. package/dist/index.d.ts.map +1 -0
  9. package/dist/index.js +35 -0
  10. package/dist/index.js.map +1 -0
  11. package/dist/lib/index.d.ts +12 -0
  12. package/dist/lib/index.d.ts.map +1 -0
  13. package/dist/lib/index.js +52 -0
  14. package/dist/lib/index.js.map +1 -0
  15. package/dist/middlewares/body-parser.d.ts +3 -0
  16. package/dist/middlewares/body-parser.d.ts.map +1 -0
  17. package/dist/middlewares/body-parser.js +29 -0
  18. package/dist/middlewares/body-parser.js.map +1 -0
  19. package/dist/middlewares/cookie-parser.d.ts +3 -0
  20. package/dist/middlewares/cookie-parser.d.ts.map +1 -0
  21. package/dist/middlewares/cookie-parser.js +20 -0
  22. package/dist/middlewares/cookie-parser.js.map +1 -0
  23. package/dist/middlewares/cors.d.ts +10 -0
  24. package/dist/middlewares/cors.d.ts.map +1 -0
  25. package/dist/middlewares/cors.js +28 -0
  26. package/dist/middlewares/cors.js.map +1 -0
  27. package/dist/middlewares/logger.d.ts +3 -0
  28. package/dist/middlewares/logger.d.ts.map +1 -0
  29. package/dist/middlewares/logger.js +28 -0
  30. package/dist/middlewares/logger.js.map +1 -0
  31. package/dist/middlewares/query-parser.d.ts +3 -0
  32. package/dist/middlewares/query-parser.d.ts.map +1 -0
  33. package/dist/middlewares/query-parser.js +29 -0
  34. package/dist/middlewares/query-parser.js.map +1 -0
  35. package/dist/middlewares/rate-limit.d.ts +9 -0
  36. package/dist/middlewares/rate-limit.d.ts.map +1 -0
  37. package/dist/middlewares/rate-limit.js +34 -0
  38. package/dist/middlewares/rate-limit.js.map +1 -0
  39. package/dist/middlewares/static-middleware.d.ts +8 -0
  40. package/dist/middlewares/static-middleware.d.ts.map +1 -0
  41. package/dist/middlewares/static-middleware.js +76 -0
  42. package/dist/middlewares/static-middleware.js.map +1 -0
  43. package/dist/router/index.d.ts +21 -0
  44. package/dist/router/index.d.ts.map +1 -0
  45. package/dist/router/index.js +130 -0
  46. package/dist/router/index.js.map +1 -0
  47. package/dist/types/index.d.ts +19 -0
  48. package/dist/types/index.d.ts.map +1 -0
  49. package/dist/types/index.js +3 -0
  50. package/dist/types/index.js.map +1 -0
  51. package/dist/util/index.d.ts +6 -0
  52. package/dist/util/index.d.ts.map +1 -0
  53. package/dist/util/index.js +18 -0
  54. package/dist/util/index.js.map +1 -0
  55. package/package.json +43 -0
package/LICENCE ADDED
@@ -0,0 +1,22 @@
1
+ ```text
2
+ MIT License
3
+
4
+ Copyright (c) 2025 Miguel Ángel (@M1HUEL) / Cahita Framework
5
+
6
+ Permission is hereby granted, free of charge, to any person obtaining a copy
7
+ of this software and associated documentation files (the "Software"), to deal
8
+ in the Software without restriction, including without limitation the rights
9
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10
+ copies of the Software, and to permit persons to whom the Software is
11
+ furnished to do so, subject to the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be included in all
14
+ copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22
+ SOFTWARE.
package/README.md ADDED
Binary file
@@ -0,0 +1,4 @@
1
+ import type { ServerResponse } from 'node:http';
2
+ import type { Response } from '../types';
3
+ export declare const augmentResponse: (res: ServerResponse) => Response;
4
+ //# sourceMappingURL=augment-response.helper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"augment-response.helper.d.ts","sourceRoot":"","sources":["../../src/helpers/augment-response.helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAExC,eAAO,MAAM,eAAe,GAAI,KAAK,cAAc,KAAG,QA0CrD,CAAC"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.augmentResponse = void 0;
4
+ const augmentResponse = (res) => {
5
+ const response = res;
6
+ response.status = function (code) {
7
+ this.statusCode = code;
8
+ return this;
9
+ };
10
+ response.send = function (body) {
11
+ if (this.writableEnded)
12
+ return this;
13
+ if (body === null || body === undefined) {
14
+ this.end();
15
+ return this;
16
+ }
17
+ if (Buffer.isBuffer(body)) {
18
+ this.setHeader('Content-Type', 'application/octet-stream');
19
+ this.end(body);
20
+ return this;
21
+ }
22
+ if (typeof body === 'object') {
23
+ return this.json(body);
24
+ }
25
+ this.setHeader('Content-Type', 'text/plain; charset=utf-8');
26
+ this.end(String(body));
27
+ return this;
28
+ };
29
+ response.json = function (data) {
30
+ if (this.writableEnded)
31
+ return this;
32
+ const json = JSON.stringify(data);
33
+ this.setHeader('Content-Type', 'application/json; charset=utf-8');
34
+ this.end(json);
35
+ return this;
36
+ };
37
+ return response;
38
+ };
39
+ exports.augmentResponse = augmentResponse;
40
+ //# sourceMappingURL=augment-response.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"augment-response.helper.js","sourceRoot":"","sources":["../../src/helpers/augment-response.helper.ts"],"names":[],"mappings":";;;AAGO,MAAM,eAAe,GAAG,CAAC,GAAmB,EAAY,EAAE;IAC/D,MAAM,QAAQ,GAAG,GAAe,CAAC;IAEjC,QAAQ,CAAC,MAAM,GAAG,UAAU,IAAY;QACtC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,QAAQ,CAAC,IAAI,GAAG,UAAU,IAAa;QACrC,IAAI,IAAI,CAAC,aAAa;YAAE,OAAO,IAAI,CAAC;QAEpC,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;YACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,0BAA0B,CAAC,CAAC;YAC3D,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,2BAA2B,CAAC,CAAC;QAC5D,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACvB,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,QAAQ,CAAC,IAAI,GAAG,UAAU,IAAa;QACrC,IAAI,IAAI,CAAC,aAAa;YAAE,OAAO,IAAI,CAAC;QAEpC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAElC,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,iCAAiC,CAAC,CAAC;QAClE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACf,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC;AA1CW,QAAA,eAAe,mBA0C1B"}
@@ -0,0 +1,10 @@
1
+ export { Application } from './lib';
2
+ export { jsonParser } from './middlewares/body-parser';
3
+ export { cookieParser } from './middlewares/cookie-parser';
4
+ export { logger } from './middlewares/logger';
5
+ export { queryParser } from './middlewares/query-parser';
6
+ export { rateLimit } from './middlewares/rate-limit';
7
+ export { staticMiddleware } from './middlewares/static-middleware';
8
+ export { Router } from './router';
9
+ export * from './types';
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,cAAc,SAAS,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.Router = exports.staticMiddleware = exports.rateLimit = exports.queryParser = exports.logger = exports.cookieParser = exports.jsonParser = exports.Application = void 0;
18
+ var lib_1 = require("./lib");
19
+ Object.defineProperty(exports, "Application", { enumerable: true, get: function () { return lib_1.Application; } });
20
+ var body_parser_1 = require("./middlewares/body-parser");
21
+ Object.defineProperty(exports, "jsonParser", { enumerable: true, get: function () { return body_parser_1.jsonParser; } });
22
+ var cookie_parser_1 = require("./middlewares/cookie-parser");
23
+ Object.defineProperty(exports, "cookieParser", { enumerable: true, get: function () { return cookie_parser_1.cookieParser; } });
24
+ var logger_1 = require("./middlewares/logger");
25
+ Object.defineProperty(exports, "logger", { enumerable: true, get: function () { return logger_1.logger; } });
26
+ var query_parser_1 = require("./middlewares/query-parser");
27
+ Object.defineProperty(exports, "queryParser", { enumerable: true, get: function () { return query_parser_1.queryParser; } });
28
+ var rate_limit_1 = require("./middlewares/rate-limit");
29
+ Object.defineProperty(exports, "rateLimit", { enumerable: true, get: function () { return rate_limit_1.rateLimit; } });
30
+ var static_middleware_1 = require("./middlewares/static-middleware");
31
+ Object.defineProperty(exports, "staticMiddleware", { enumerable: true, get: function () { return static_middleware_1.staticMiddleware; } });
32
+ var router_1 = require("./router");
33
+ Object.defineProperty(exports, "Router", { enumerable: true, get: function () { return router_1.Router; } });
34
+ __exportStar(require("./types"), exports);
35
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,6BAAoC;AAA3B,kGAAA,WAAW,OAAA;AACpB,yDAAuD;AAA9C,yGAAA,UAAU,OAAA;AACnB,6DAA2D;AAAlD,6GAAA,YAAY,OAAA;AACrB,+CAA8C;AAArC,gGAAA,MAAM,OAAA;AACf,2DAAyD;AAAhD,2GAAA,WAAW,OAAA;AACpB,uDAAqD;AAA5C,uGAAA,SAAS,OAAA;AAClB,qEAAmE;AAA1D,qHAAA,gBAAgB,OAAA;AACzB,mCAAkC;AAAzB,gGAAA,MAAM,OAAA;AACf,0CAAwB"}
@@ -0,0 +1,12 @@
1
+ import { Router } from '../router';
2
+ import type { Handler, Middleware } from '../types';
3
+ export declare class Application {
4
+ private router;
5
+ constructor();
6
+ use(path: string | Middleware | Router, ...handlers: (Middleware | Router)[]): void;
7
+ get(path: string, ...handlers: Handler[]): void;
8
+ post(path: string, ...handlers: Handler[]): void;
9
+ listen(port: number, callback?: () => void): void;
10
+ private handle;
11
+ }
12
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lib/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,KAAK,EAAE,OAAO,EAAE,UAAU,EAAqB,MAAM,SAAS,CAAC;AAEtE,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAS;;IAKvB,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC,UAAU,GAAG,MAAM,CAAC,EAAE,GAAG,IAAI;IAWnF,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI;IAI/C,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI;IAIhD,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,IAAI,GAAG,IAAI;IAUjD,OAAO,CAAC,MAAM;CAcf"}
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Application = void 0;
4
+ const node_http_1 = require("node:http");
5
+ const augment_response_helper_1 = require("../helpers/augment-response.helper");
6
+ const router_1 = require("../router");
7
+ class Application {
8
+ router;
9
+ constructor() {
10
+ this.router = new router_1.Router();
11
+ }
12
+ use(path, ...handlers) {
13
+ if (typeof path === 'string') {
14
+ if (!handlers.length) {
15
+ throw new Error(`Se requiere al menos un handler para el path: ${path}`);
16
+ }
17
+ this.router.use(path, ...handlers);
18
+ }
19
+ else {
20
+ this.router.use('*', path, ...handlers);
21
+ }
22
+ }
23
+ get(path, ...handlers) {
24
+ this.router.get(path, ...handlers);
25
+ }
26
+ post(path, ...handlers) {
27
+ this.router.post(path, ...handlers);
28
+ }
29
+ listen(port, callback) {
30
+ const server = (0, node_http_1.createServer)((req, res) => {
31
+ const request = req;
32
+ const response = (0, augment_response_helper_1.augmentResponse)(res);
33
+ this.handle(request, response);
34
+ });
35
+ server.listen(port, callback);
36
+ }
37
+ handle(req, res) {
38
+ this.router.handle(req, res, (err) => {
39
+ if (res.writableEnded)
40
+ return;
41
+ if (err) {
42
+ res.status(500).json({
43
+ error: err instanceof Error ? err.message : 'Internal Server Error',
44
+ });
45
+ return;
46
+ }
47
+ res.status(404).end('Not Found');
48
+ });
49
+ }
50
+ }
51
+ exports.Application = Application;
52
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/lib/index.ts"],"names":[],"mappings":";;;AAAA,yCAAyC;AACzC,+EAAoE;AACpE,qCAAkC;AAGlC,MAAa,WAAW;IACd,MAAM,CAAS;IAEvB;QACE,IAAI,CAAC,MAAM,GAAG,IAAI,eAAM,EAAE,CAAC;IAC7B,CAAC;IACD,GAAG,CAAC,IAAkC,EAAE,GAAG,QAAiC;QAC1E,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACrB,MAAM,IAAI,KAAK,CAAC,iDAAiD,IAAI,EAAE,CAAC,CAAC;YAC3E,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,QAAQ,CAAC,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,GAAG,CAAC,IAAY,EAAE,GAAG,QAAmB;QACtC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,IAAI,CAAC,IAAY,EAAE,GAAG,QAAmB;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,QAAQ,CAAC,CAAC;IACtC,CAAC;IAED,MAAM,CAAC,IAAY,EAAE,QAAqB;QACxC,MAAM,MAAM,GAAG,IAAA,wBAAY,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YACvC,MAAM,OAAO,GAAG,GAAc,CAAC;YAC/B,MAAM,QAAQ,GAAG,IAAA,yCAAe,EAAC,GAAG,CAAC,CAAC;YAEtC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAChC,CAAC;IAEO,MAAM,CAAC,GAAY,EAAE,GAAa;QACxC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE;YACnC,IAAI,GAAG,CAAC,aAAa;gBAAE,OAAO;YAE9B,IAAI,GAAG,EAAE,CAAC;gBACR,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,KAAK,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,uBAAuB;iBACpE,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;YAED,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAjDD,kCAiDC"}
@@ -0,0 +1,3 @@
1
+ import type { Handler } from '../types';
2
+ export declare const jsonParser: Handler;
3
+ //# sourceMappingURL=body-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"body-parser.d.ts","sourceRoot":"","sources":["../../src/middlewares/body-parser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAEvC,eAAO,MAAM,UAAU,EAAE,OA2BxB,CAAC"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.jsonParser = void 0;
4
+ const jsonParser = (req, res, next) => {
5
+ const contentType = req.headers['content-type'];
6
+ if (!contentType?.includes('application/json')) {
7
+ return next();
8
+ }
9
+ let body = '';
10
+ req.on('data', (chunk) => {
11
+ body += chunk.toString();
12
+ });
13
+ req.on('end', () => {
14
+ if (!body)
15
+ return next();
16
+ try {
17
+ req.body = JSON.parse(body);
18
+ next();
19
+ }
20
+ catch {
21
+ if (!res.writableEnded) {
22
+ res.status(400).json({ error: 'Invalid JSON body' });
23
+ }
24
+ }
25
+ });
26
+ req.on('error', next);
27
+ };
28
+ exports.jsonParser = jsonParser;
29
+ //# sourceMappingURL=body-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"body-parser.js","sourceRoot":"","sources":["../../src/middlewares/body-parser.ts"],"names":[],"mappings":";;;AAEO,MAAM,UAAU,GAAY,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACpD,MAAM,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IAEhD,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;QAC/C,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,IAAI,IAAI,GAAG,EAAE,CAAC;IAEd,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;QACvB,IAAI,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;QACjB,IAAI,CAAC,IAAI;YAAE,OAAO,IAAI,EAAE,CAAC;QAEzB,IAAI,CAAC;YACH,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,EAAE,CAAC;QACT,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBACvB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC,CAAC;YACvD,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AACxB,CAAC,CAAC;AA3BW,QAAA,UAAU,cA2BrB"}
@@ -0,0 +1,3 @@
1
+ import type { Middleware } from '../types';
2
+ export declare const cookieParser: () => Middleware;
3
+ //# sourceMappingURL=cookie-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cookie-parser.d.ts","sourceRoot":"","sources":["../../src/middlewares/cookie-parser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAE3E,eAAO,MAAM,YAAY,QAAO,UAgB/B,CAAC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.cookieParser = void 0;
4
+ const cookieParser = () => {
5
+ return (req, _res, next) => {
6
+ const header = req.headers.cookie;
7
+ req.cookies = {};
8
+ if (header) {
9
+ header.split(';').forEach((cookie) => {
10
+ const [name, ...rest] = cookie.split('=');
11
+ if (name) {
12
+ req.cookies[name.trim()] = decodeURIComponent(rest.join('='));
13
+ }
14
+ });
15
+ }
16
+ next();
17
+ };
18
+ };
19
+ exports.cookieParser = cookieParser;
20
+ //# sourceMappingURL=cookie-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cookie-parser.js","sourceRoot":"","sources":["../../src/middlewares/cookie-parser.ts"],"names":[],"mappings":";;;AAEO,MAAM,YAAY,GAAG,GAAe,EAAE;IAC3C,OAAO,CAAC,GAAY,EAAE,IAAc,EAAE,IAAkB,EAAE,EAAE;QAC1D,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC;QAClC,GAAG,CAAC,OAAO,GAAG,EAAE,CAAC;QAEjB,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACnC,MAAM,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBAC1C,IAAI,IAAI,EAAE,CAAC;oBACT,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBAChE,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AAhBW,QAAA,YAAY,gBAgBvB"}
@@ -0,0 +1,10 @@
1
+ import type { Middleware } from '../types';
2
+ interface CorsOptions {
3
+ origin?: string | ((reqOrigin: string | undefined) => string);
4
+ methods?: string[];
5
+ allowedHeaders?: string[];
6
+ credentials?: boolean;
7
+ }
8
+ export declare const cors: (options?: CorsOptions) => Middleware;
9
+ export {};
10
+ //# sourceMappingURL=cors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cors.d.ts","sourceRoot":"","sources":["../../src/middlewares/cors.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAE3E,UAAU,WAAW;IACnB,MAAM,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,KAAK,MAAM,CAAC,CAAC;IAC9D,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,eAAO,MAAM,IAAI,GAAI,UAAS,WAAgB,KAAG,UAgChD,CAAC"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.cors = void 0;
4
+ const cors = (options = {}) => {
5
+ const { origin = '*', methods = ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS'], allowedHeaders = ['Content-Type', 'Authorization'], credentials = false, } = options;
6
+ return (req, res, next) => {
7
+ const requestOrigin = req.headers.origin;
8
+ let allowedOrigin = typeof origin === 'function' ? origin(requestOrigin) : origin;
9
+ if (credentials) {
10
+ if (allowedOrigin === '*') {
11
+ allowedOrigin = requestOrigin || '';
12
+ }
13
+ res.setHeader('Access-Control-Allow-Credentials', 'true');
14
+ }
15
+ res.setHeader('Vary', 'Origin');
16
+ res.setHeader('Access-Control-Allow-Origin', allowedOrigin);
17
+ res.setHeader('Access-Control-Allow-Methods', methods.join(','));
18
+ res.setHeader('Access-Control-Allow-Headers', allowedHeaders.join(','));
19
+ if (req.method === 'OPTIONS') {
20
+ res.setHeader('Access-Control-Max-Age', '86400');
21
+ res.status(204).end();
22
+ return;
23
+ }
24
+ next();
25
+ };
26
+ };
27
+ exports.cors = cors;
28
+ //# sourceMappingURL=cors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cors.js","sourceRoot":"","sources":["../../src/middlewares/cors.ts"],"names":[],"mappings":";;;AASO,MAAM,IAAI,GAAG,CAAC,UAAuB,EAAE,EAAc,EAAE;IAC5D,MAAM,EACJ,MAAM,GAAG,GAAG,EACZ,OAAO,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,CAAC,EACrD,cAAc,GAAG,CAAC,cAAc,EAAE,eAAe,CAAC,EAClD,WAAW,GAAG,KAAK,GACpB,GAAG,OAAO,CAAC;IAEZ,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;QACzD,MAAM,aAAa,GAAG,GAAG,CAAC,OAAO,CAAC,MAAgB,CAAC;QACnD,IAAI,aAAa,GAAG,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QAElF,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,aAAa,KAAK,GAAG,EAAE,CAAC;gBAC1B,aAAa,GAAG,aAAa,IAAI,EAAE,CAAC;YACtC,CAAC;YACD,GAAG,CAAC,SAAS,CAAC,kCAAkC,EAAE,MAAM,CAAC,CAAC;QAC5D,CAAC;QAED,GAAG,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAChC,GAAG,CAAC,SAAS,CAAC,6BAA6B,EAAE,aAAa,CAAC,CAAC;QAC5D,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QACjE,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAExE,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC7B,GAAG,CAAC,SAAS,CAAC,wBAAwB,EAAE,OAAO,CAAC,CAAC;YACjD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AAhCW,QAAA,IAAI,QAgCf"}
@@ -0,0 +1,3 @@
1
+ import type { Middleware } from '../types';
2
+ export declare const logger: () => Middleware;
3
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/middlewares/logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAE3E,eAAO,MAAM,MAAM,QAAO,UA0BzB,CAAC"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.logger = void 0;
4
+ const logger = () => {
5
+ return (req, res, next) => {
6
+ const start = performance.now();
7
+ const { method, url } = req;
8
+ res.on('finish', () => {
9
+ const duration = (performance.now() - start).toFixed(2);
10
+ const status = res.statusCode;
11
+ let color = '\x1b[32m'; // 2xx
12
+ if (status >= 400 && status < 500)
13
+ color = '\x1b[33m'; // 4xx
14
+ if (status >= 500)
15
+ color = '\x1b[31m'; // 5xx
16
+ if (status >= 300 && status < 400)
17
+ color = '\x1b[34m'; // 3xx
18
+ const reset = '\x1b[0m';
19
+ const white = '\x1b[37m';
20
+ console.log(`${white}[${new Date().toLocaleTimeString()}]${reset} ` +
21
+ `${color}${method}${reset} ${white}${url}${reset} ` +
22
+ `${color}${status}${reset} - ${duration}ms`);
23
+ });
24
+ next();
25
+ };
26
+ };
27
+ exports.logger = logger;
28
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/middlewares/logger.ts"],"names":[],"mappings":";;;AAEO,MAAM,MAAM,GAAG,GAAe,EAAE;IACrC,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;QACzD,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;QAChC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,GAAG,CAAC;QAE5B,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;YACpB,MAAM,QAAQ,GAAG,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACxD,MAAM,MAAM,GAAG,GAAG,CAAC,UAAU,CAAC;YAE9B,IAAI,KAAK,GAAG,UAAU,CAAC,CAAC,MAAM;YAC9B,IAAI,MAAM,IAAI,GAAG,IAAI,MAAM,GAAG,GAAG;gBAAE,KAAK,GAAG,UAAU,CAAC,CAAC,MAAM;YAC7D,IAAI,MAAM,IAAI,GAAG;gBAAE,KAAK,GAAG,UAAU,CAAC,CAAC,MAAM;YAC7C,IAAI,MAAM,IAAI,GAAG,IAAI,MAAM,GAAG,GAAG;gBAAE,KAAK,GAAG,UAAU,CAAC,CAAC,MAAM;YAE7D,MAAM,KAAK,GAAG,SAAS,CAAC;YACxB,MAAM,KAAK,GAAG,UAAU,CAAC;YAEzB,OAAO,CAAC,GAAG,CACT,GAAG,KAAK,IAAI,IAAI,IAAI,EAAE,CAAC,kBAAkB,EAAE,IAAI,KAAK,GAAG;gBACrD,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,IAAI,KAAK,GAAG,GAAG,GAAG,KAAK,GAAG;gBACnD,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,MAAM,QAAQ,IAAI,CAC9C,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AA1BW,QAAA,MAAM,UA0BjB"}
@@ -0,0 +1,3 @@
1
+ import type { Middleware } from '../types';
2
+ export declare const queryParser: () => Middleware;
3
+ //# sourceMappingURL=query-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-parser.d.ts","sourceRoot":"","sources":["../../src/middlewares/query-parser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAG3E,eAAO,MAAM,WAAW,QAAO,UAuB9B,CAAC"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.queryParser = void 0;
4
+ const util_1 = require("../util");
5
+ const queryParser = () => {
6
+ return (req, _res, next) => {
7
+ const url = req.url || '/';
8
+ const urlObj = new URL(url, 'http://localhost');
9
+ const params = {};
10
+ urlObj.searchParams.forEach((value, key) => {
11
+ const parsedValue = (0, util_1.parseValue)(value);
12
+ if (params[key] !== undefined) {
13
+ if (Array.isArray(params[key])) {
14
+ params[key].push(String(parsedValue));
15
+ }
16
+ else {
17
+ params[key] = [String(params[key]), String(parsedValue)];
18
+ }
19
+ }
20
+ else {
21
+ params[key] = parsedValue;
22
+ }
23
+ });
24
+ req.query = { ...(req.query || {}), ...params };
25
+ next();
26
+ };
27
+ };
28
+ exports.queryParser = queryParser;
29
+ //# sourceMappingURL=query-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-parser.js","sourceRoot":"","sources":["../../src/middlewares/query-parser.ts"],"names":[],"mappings":";;;AACA,iCAAoC;AAE7B,MAAM,WAAW,GAAG,GAAe,EAAE;IAC1C,OAAO,CAAC,GAAY,EAAE,IAAc,EAAE,IAAkB,EAAE,EAAE;QAC1D,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC;QAC3B,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;QAChD,MAAM,MAAM,GAAyD,EAAE,CAAC;QAExE,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YACzC,MAAM,WAAW,GAAG,IAAA,iBAAU,EAAC,KAAK,CAAC,CAAC;YAEtC,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS,EAAE,CAAC;gBAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC9B,MAAM,CAAC,GAAG,CAAc,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;gBACtD,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;gBAC3D,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,KAAK,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC;QAChD,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AAvBW,QAAA,WAAW,eAuBtB"}
@@ -0,0 +1,9 @@
1
+ import type { Middleware } from '../types';
2
+ interface RateLimitOptions {
3
+ windowMs: number;
4
+ max: number;
5
+ message?: string;
6
+ }
7
+ export declare const rateLimit: (options: RateLimitOptions) => Middleware;
8
+ export {};
9
+ //# sourceMappingURL=rate-limit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limit.d.ts","sourceRoot":"","sources":["../../src/middlewares/rate-limit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAE3E,UAAU,gBAAgB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,eAAO,MAAM,SAAS,GAAI,SAAS,gBAAgB,KAAG,UAmCrD,CAAC"}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rateLimit = void 0;
4
+ const rateLimit = (options) => {
5
+ const { windowMs, max, message = 'Demasiadas peticiones, intente más tarde.' } = options;
6
+ const hits = new Map();
7
+ setInterval(() => {
8
+ const now = Date.now();
9
+ for (const [ip, data] of hits.entries()) {
10
+ if (now > data.resetTime)
11
+ hits.delete(ip);
12
+ }
13
+ }, windowMs);
14
+ return (req, res, next) => {
15
+ const ip = req.headers['x-forwarded-for'] || req.socket.remoteAddress || 'unknown';
16
+ const now = Date.now();
17
+ let clientData = hits.get(ip);
18
+ if (!clientData || now > clientData.resetTime) {
19
+ clientData = { count: 0, resetTime: now + windowMs };
20
+ }
21
+ clientData.count++;
22
+ hits.set(ip, clientData);
23
+ res.setHeader('X-RateLimit-Limit', max);
24
+ res.setHeader('X-RateLimit-Remaining', Math.max(0, max - clientData.count));
25
+ res.setHeader('X-RateLimit-Reset', Math.ceil(clientData.resetTime / 1000));
26
+ if (clientData.count > max) {
27
+ res.status(429).json({ error: message });
28
+ return;
29
+ }
30
+ next();
31
+ };
32
+ };
33
+ exports.rateLimit = rateLimit;
34
+ //# sourceMappingURL=rate-limit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limit.js","sourceRoot":"","sources":["../../src/middlewares/rate-limit.ts"],"names":[],"mappings":";;;AAQO,MAAM,SAAS,GAAG,CAAC,OAAyB,EAAc,EAAE;IACjE,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,OAAO,GAAG,2CAA2C,EAAE,GAAG,OAAO,CAAC;IACzF,MAAM,IAAI,GAAG,IAAI,GAAG,EAAgD,CAAC;IAErE,WAAW,CAAC,GAAG,EAAE;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,KAAK,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACxC,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS;gBAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC,EAAE,QAAQ,CAAC,CAAC;IAEb,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;QACzD,MAAM,EAAE,GAAI,GAAG,CAAC,OAAO,CAAC,iBAAiB,CAAY,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,IAAI,SAAS,CAAC;QAC/F,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,IAAI,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE9B,IAAI,CAAC,UAAU,IAAI,GAAG,GAAG,UAAU,CAAC,SAAS,EAAE,CAAC;YAC9C,UAAU,GAAG,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,GAAG,QAAQ,EAAE,CAAC;QACvD,CAAC;QAED,UAAU,CAAC,KAAK,EAAE,CAAC;QACnB,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QAEzB,GAAG,CAAC,SAAS,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;QACxC,GAAG,CAAC,SAAS,CAAC,uBAAuB,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5E,GAAG,CAAC,SAAS,CAAC,mBAAmB,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC;QAE3E,IAAI,UAAU,CAAC,KAAK,GAAG,GAAG,EAAE,CAAC;YAC3B,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;QAED,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AAnCW,QAAA,SAAS,aAmCpB"}
@@ -0,0 +1,8 @@
1
+ import type { Middleware } from '../types';
2
+ interface StaticMiddlewareOptions {
3
+ gzip?: boolean;
4
+ cacheMaxAge?: number;
5
+ }
6
+ export declare const staticMiddleware: (root: string, options?: StaticMiddlewareOptions) => Middleware;
7
+ export {};
8
+ //# sourceMappingURL=static-middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static-middleware.d.ts","sourceRoot":"","sources":["../../src/middlewares/static-middleware.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAmC,MAAM,SAAS,CAAC;AAG3E,UAAU,uBAAuB;IAC/B,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,gBAAgB,GAAI,MAAM,MAAM,EAAE,UAAS,uBAA4B,KAAG,UAqEtF,CAAC"}
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.staticMiddleware = void 0;
7
+ const node_fs_1 = require("node:fs");
8
+ const node_path_1 = require("node:path");
9
+ const node_zlib_1 = require("node:zlib");
10
+ const mime_types_1 = __importDefault(require("mime-types"));
11
+ const util_1 = require("../util");
12
+ const staticMiddleware = (root, options = {}) => {
13
+ const rootPath = (0, node_path_1.resolve)(root);
14
+ const gzipEnabled = options.gzip ?? true;
15
+ const cacheMaxAge = options.cacheMaxAge ?? 3600;
16
+ return async (req, res, next) => {
17
+ if (req.method !== 'GET' && req.method !== 'HEAD') {
18
+ next();
19
+ return;
20
+ }
21
+ try {
22
+ const urlPath = req.url?.split('?')[0] || '/';
23
+ const relativePath = decodeURIComponent(urlPath).replace(/^\/+/, '');
24
+ let safePath = (0, node_path_1.join)(rootPath, relativePath || '.');
25
+ if (!safePath.startsWith(rootPath)) {
26
+ res.status(403).end('Forbidden');
27
+ return;
28
+ }
29
+ let stats;
30
+ try {
31
+ stats = await node_fs_1.promises.stat(safePath);
32
+ }
33
+ catch {
34
+ next();
35
+ return;
36
+ }
37
+ if (stats.isDirectory()) {
38
+ const indexFile = (0, node_path_1.join)(safePath, 'index.html');
39
+ try {
40
+ stats = await node_fs_1.promises.stat(indexFile);
41
+ safePath = indexFile;
42
+ }
43
+ catch {
44
+ next();
45
+ return;
46
+ }
47
+ }
48
+ const contentType = mime_types_1.default.lookup(safePath) || 'application/octet-stream';
49
+ res.setHeader('Content-Type', contentType);
50
+ res.setHeader('Cache-Control', `public, max-age=${cacheMaxAge}`);
51
+ res.setHeader('Vary', 'Accept-Encoding');
52
+ if (req.method === 'HEAD') {
53
+ res.setHeader('Content-Length', stats.size);
54
+ res.end();
55
+ return;
56
+ }
57
+ const acceptEncoding = req.headers['accept-encoding'] || '';
58
+ const shouldCompress = gzipEnabled && acceptEncoding.includes('gzip') && (0, util_1.isCompressible)(contentType);
59
+ const fileStream = (0, node_fs_1.createReadStream)(safePath);
60
+ if (shouldCompress) {
61
+ res.setHeader('Content-Encoding', 'gzip');
62
+ const gzip = (0, node_zlib_1.createGzip)();
63
+ fileStream.pipe(gzip).on('error', next).pipe(res);
64
+ }
65
+ else {
66
+ res.setHeader('Content-Length', stats.size);
67
+ fileStream.pipe(res).on('error', next);
68
+ }
69
+ }
70
+ catch (err) {
71
+ next(err);
72
+ }
73
+ };
74
+ };
75
+ exports.staticMiddleware = staticMiddleware;
76
+ //# sourceMappingURL=static-middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"static-middleware.js","sourceRoot":"","sources":["../../src/middlewares/static-middleware.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import type { Middleware, NextFunction, Request, Response } from '../types';
2
+ export declare class Layer {
3
+ readonly path: string;
4
+ readonly handler: Middleware | Router;
5
+ readonly method?: string;
6
+ readonly isErrorHandler: boolean;
7
+ private regexp;
8
+ private keys;
9
+ constructor(path: string, handler: Middleware | Router, method?: string);
10
+ private compilePath;
11
+ match(path: string, method: string): boolean;
12
+ handleRequest(path: string, err: unknown, req: Request, res: Response, next: NextFunction): void;
13
+ }
14
+ export declare class Router {
15
+ private stack;
16
+ use(path: string | Middleware | Router, ...handlers: (Middleware | Router)[]): void;
17
+ get(path: string, ...handlers: Middleware[]): void;
18
+ post(path: string, ...handlers: Middleware[]): void;
19
+ handle(req: Request, res: Response, out: NextFunction): void;
20
+ }
21
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/router/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAM3E,qBAAa,KAAK;IAChB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,OAAO,EAAE,UAAU,GAAG,MAAM,CAAC;IACtC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,cAAc,EAAE,OAAO,CAAC;IACjC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,IAAI,CAAgB;gBAEhB,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,GAAG,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM;IAavE,OAAO,CAAC,WAAW;IAWnB,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO;IAK5C,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,GAAG,IAAI;CAiDjG;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,KAAK,CAAe;IAE5B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC,UAAU,GAAG,MAAM,CAAC,EAAE,GAAG,IAAI;IAanF,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAI;IAMlD,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAI;IAMnD,MAAM,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,YAAY,GAAG,IAAI;CAuB7D"}
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Router = exports.Layer = void 0;
4
+ const util_1 = require("../util");
5
+ class Layer {
6
+ path;
7
+ handler;
8
+ method;
9
+ isErrorHandler;
10
+ regexp;
11
+ keys = [];
12
+ constructor(path, handler, method) {
13
+ this.path = path;
14
+ this.handler = handler;
15
+ this.method = method?.toUpperCase();
16
+ this.isErrorHandler = typeof handler === 'function' && handler.length === 4;
17
+ const isSubRouter = (0, util_1.isRouter)(handler);
18
+ const isMiddleware = !method;
19
+ const end = !(isSubRouter || isMiddleware || path === '*');
20
+ this.regexp = this.compilePath(path, end);
21
+ }
22
+ compilePath(path, end) {
23
+ if (path === '*')
24
+ return /.*/;
25
+ const parsed = path.replace(/:([^/]+)/g, (_, key) => {
26
+ this.keys.push(key);
27
+ return '([^/]+)';
28
+ });
29
+ return new RegExp(`^${parsed}${end ? '/?$' : '(?=/|$)'}`, 'i');
30
+ }
31
+ match(path, method) {
32
+ if (this.method && this.method !== method.toUpperCase())
33
+ return false;
34
+ return this.regexp.test(path);
35
+ }
36
+ handleRequest(path, err, req, res, next) {
37
+ const match = path.match(this.regexp);
38
+ if (match) {
39
+ const values = match.slice(1);
40
+ req.params = {
41
+ ...req.params,
42
+ ...this.keys.reduce((params, key, index) => {
43
+ params[key] = values[index];
44
+ return params;
45
+ }, {}),
46
+ };
47
+ }
48
+ if ((0, util_1.isRouter)(this.handler)) {
49
+ const originalUrl = req.url ?? '/';
50
+ const basePathMatch = path.match(this.regexp);
51
+ const basePathLength = basePathMatch?.[0].length ?? 0;
52
+ req.url = originalUrl.slice(basePathLength) || '/';
53
+ this.handler.handle(req, res, (subErr) => {
54
+ req.url = originalUrl;
55
+ next(subErr ?? err);
56
+ });
57
+ return;
58
+ }
59
+ try {
60
+ if (this.isErrorHandler) {
61
+ if (err) {
62
+ const handler = this.handler;
63
+ Promise.resolve(handler(err, req, res, next)).catch(next);
64
+ }
65
+ else {
66
+ next();
67
+ }
68
+ }
69
+ else {
70
+ if (!err) {
71
+ const handler = this.handler;
72
+ Promise.resolve(handler(req, res, next)).catch(next);
73
+ }
74
+ else {
75
+ next(err);
76
+ }
77
+ }
78
+ }
79
+ catch (e) {
80
+ next(e);
81
+ }
82
+ }
83
+ }
84
+ exports.Layer = Layer;
85
+ class Router {
86
+ stack = [];
87
+ use(path, ...handlers) {
88
+ if (typeof path === 'string') {
89
+ for (const handler of handlers) {
90
+ this.stack.push(new Layer(path, handler));
91
+ }
92
+ }
93
+ else {
94
+ this.stack.push(new Layer('*', path));
95
+ for (const h of handlers) {
96
+ this.stack.push(new Layer('*', h));
97
+ }
98
+ }
99
+ }
100
+ get(path, ...handlers) {
101
+ for (const handler of handlers) {
102
+ this.stack.push(new Layer(path, handler, 'GET'));
103
+ }
104
+ }
105
+ post(path, ...handlers) {
106
+ for (const handler of handlers) {
107
+ this.stack.push(new Layer(path, handler, 'POST'));
108
+ }
109
+ }
110
+ handle(req, res, out) {
111
+ let index = 0;
112
+ const path = req.url?.split('?')[0] || '/';
113
+ const method = req.method || 'GET';
114
+ const next = (err) => {
115
+ if (index >= this.stack.length) {
116
+ out(err);
117
+ return;
118
+ }
119
+ const layer = this.stack[index++];
120
+ if (!layer.match(path, method)) {
121
+ next(err);
122
+ return;
123
+ }
124
+ layer.handleRequest(path, err, req, res, next);
125
+ };
126
+ next();
127
+ }
128
+ }
129
+ exports.Router = Router;
130
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/router/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import type { IncomingMessage, ServerResponse } from 'node:http';
2
+ import type { Router } from '../router';
3
+ export interface Request<Params = Record<string, string>, Query = Record<string, string | string[] | number | boolean | undefined>, Body = unknown> extends IncomingMessage {
4
+ params: Params;
5
+ query: Query;
6
+ body?: Body;
7
+ cookies: Record<string, string>;
8
+ }
9
+ export interface Response extends ServerResponse {
10
+ send(body: unknown): Response;
11
+ json(data: unknown): Response;
12
+ status(code: number): Response;
13
+ }
14
+ export type NextFunction = (err?: unknown) => void;
15
+ export type Handler = (req: Request, res: Response, next: NextFunction) => void | Promise<void>;
16
+ export type ErrorHandler = (err: unknown, req: Request, res: Response, next: NextFunction) => void | Promise<void>;
17
+ export type Middleware = Handler | ErrorHandler;
18
+ export type LayerHandler = Middleware | Router;
19
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAEvC,MAAM,WAAW,OAAO,CACtB,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC/B,KAAK,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC,EACxE,IAAI,GAAG,OAAO,CACd,SAAQ,eAAe;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,KAAK,CAAC;IACb,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACjC;AAED,MAAM,WAAW,QAAS,SAAQ,cAAc;IAC9C,IAAI,CAAC,IAAI,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC9B,IAAI,CAAC,IAAI,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC9B,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC;CAChC;AAED,MAAM,MAAM,YAAY,GAAG,CAAC,GAAG,CAAC,EAAE,OAAO,KAAK,IAAI,CAAC;AAEnD,MAAM,MAAM,OAAO,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAEhG,MAAM,MAAM,YAAY,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAEnH,MAAM,MAAM,UAAU,GAAG,OAAO,GAAG,YAAY,CAAC;AAEhD,MAAM,MAAM,YAAY,GAAG,UAAU,GAAG,MAAM,CAAC"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ import type { Router } from '../router';
2
+ import type { Middleware } from '../types';
3
+ export declare const isRouter: (handler: Middleware | Router) => handler is Router;
4
+ export declare const parseValue: (value: string) => string | number | boolean;
5
+ export declare const isCompressible: (contentType: string) => boolean;
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/util/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAE1C,eAAO,MAAM,QAAQ,GAAI,SAAS,UAAU,GAAG,MAAM,KAAG,OAAO,IAAI,MACc,CAAC;AAElF,eAAO,MAAM,UAAU,GAAI,OAAO,MAAM,8BAKvC,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,aAAa,MAAM,KAAG,OAA8D,CAAC"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isCompressible = exports.parseValue = exports.isRouter = void 0;
4
+ const isRouter = (handler) => typeof handler === 'object' && typeof handler.handle === 'function';
5
+ exports.isRouter = isRouter;
6
+ const parseValue = (value) => {
7
+ if (value === 'true')
8
+ return true;
9
+ if (value === 'false')
10
+ return false;
11
+ if (!Number.isNaN(Number(value)))
12
+ return Number(value);
13
+ return value;
14
+ };
15
+ exports.parseValue = parseValue;
16
+ const isCompressible = (contentType) => /text\/|javascript|json|html|css/.test(contentType);
17
+ exports.isCompressible = isCompressible;
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/util/index.ts"],"names":[],"mappings":";;;AAGO,MAAM,QAAQ,GAAG,CAAC,OAA4B,EAAqB,EAAE,CAC1E,OAAO,OAAO,KAAK,QAAQ,IAAI,OAAQ,OAAkB,CAAC,MAAM,KAAK,UAAU,CAAC;AADrE,QAAA,QAAQ,YAC6D;AAE3E,MAAM,UAAU,GAAG,CAAC,KAAa,EAAE,EAAE;IAC1C,IAAI,KAAK,KAAK,MAAM;QAAE,OAAO,IAAI,CAAC;IAClC,IAAI,KAAK,KAAK,OAAO;QAAE,OAAO,KAAK,CAAC;IACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACvD,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AALW,QAAA,UAAU,cAKrB;AAEK,MAAM,cAAc,GAAG,CAAC,WAAmB,EAAW,EAAE,CAAC,iCAAiC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;AAAvG,QAAA,cAAc,kBAAyF"}
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "cahita",
3
+ "version": "1.0.0",
4
+ "description": "A high-performance, async-first web framework for Node.js",
5
+ "main": "./dist/index.js",
6
+ "types": "./dist/index.d.ts",
7
+ "files": [
8
+ "dist"
9
+ ],
10
+ "scripts": {
11
+ "build": "tsc && tsc-alias",
12
+ "prepublishOnly": "npm run build",
13
+ "lint": "biome check src/",
14
+ "check": "biome check --write src/",
15
+ "format": "biome format --write src/"
16
+ },
17
+ "keywords": [
18
+ "framework",
19
+ "node",
20
+ "typescript",
21
+ "async",
22
+ "express-alternative",
23
+ "minimalist"
24
+ ],
25
+ "author": "Miguel Ángel (@M1HUEL)",
26
+ "license": "MIT",
27
+ "repository": {
28
+ "type": "git",
29
+ "url": "git+https://github.com/M1HUEL/cahita.git"
30
+ },
31
+ "type": "commonjs",
32
+ "devDependencies": {
33
+ "@biomejs/biome": "2.3.10",
34
+ "@types/mime-types": "^3.0.4",
35
+ "@types/node": "^22.10.5",
36
+ "tsc-alias": "^1.8.10",
37
+ "tsx": "^4.19.2",
38
+ "typescript": "^5.7.2"
39
+ },
40
+ "dependencies": {
41
+ "mime-types": "^2.1.35"
42
+ }
43
+ }