@shadimakhoul/ggcoach 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 (134) hide show
  1. package/config/config.ts +7 -0
  2. package/config/index.ts +2 -0
  3. package/config/initExpress.ts +27 -0
  4. package/config/redis.ts +38 -0
  5. package/config/swagger-ui.ts +84 -0
  6. package/config/swagger.ts +4417 -0
  7. package/dist/config/config.d.ts +8 -0
  8. package/dist/config/config.d.ts.map +1 -0
  9. package/dist/config/config.js +11 -0
  10. package/dist/config/config.js.map +1 -0
  11. package/dist/config/index.d.ts +3 -0
  12. package/dist/config/index.d.ts.map +1 -0
  13. package/dist/config/index.js +19 -0
  14. package/dist/config/index.js.map +1 -0
  15. package/dist/config/initExpress.d.ts +2 -0
  16. package/dist/config/initExpress.d.ts.map +1 -0
  17. package/dist/config/initExpress.js +29 -0
  18. package/dist/config/initExpress.js.map +1 -0
  19. package/dist/config/redis.d.ts +6 -0
  20. package/dist/config/redis.d.ts.map +1 -0
  21. package/dist/config/redis.js +34 -0
  22. package/dist/config/redis.js.map +1 -0
  23. package/dist/config/swagger-ui.d.ts +6 -0
  24. package/dist/config/swagger-ui.d.ts.map +1 -0
  25. package/dist/config/swagger-ui.js +88 -0
  26. package/dist/config/swagger-ui.js.map +1 -0
  27. package/dist/config/swagger.d.ts +9 -0
  28. package/dist/config/swagger.d.ts.map +1 -0
  29. package/dist/config/swagger.js +4406 -0
  30. package/dist/config/swagger.js.map +1 -0
  31. package/dist/index.d.ts +5 -0
  32. package/dist/index.d.ts.map +1 -0
  33. package/dist/index.js +21 -0
  34. package/dist/index.js.map +1 -0
  35. package/dist/middleware/admin-auth.d.ts +4 -0
  36. package/dist/middleware/admin-auth.d.ts.map +1 -0
  37. package/dist/middleware/admin-auth.js +55 -0
  38. package/dist/middleware/admin-auth.js.map +1 -0
  39. package/dist/middleware/auth.d.ts +4 -0
  40. package/dist/middleware/auth.d.ts.map +1 -0
  41. package/dist/middleware/auth.js +86 -0
  42. package/dist/middleware/auth.js.map +1 -0
  43. package/dist/middleware/cors.d.ts +16 -0
  44. package/dist/middleware/cors.d.ts.map +1 -0
  45. package/dist/middleware/cors.js +45 -0
  46. package/dist/middleware/cors.js.map +1 -0
  47. package/dist/middleware/errorHandler.d.ts +3 -0
  48. package/dist/middleware/errorHandler.d.ts.map +1 -0
  49. package/dist/middleware/errorHandler.js +58 -0
  50. package/dist/middleware/errorHandler.js.map +1 -0
  51. package/dist/middleware/index.d.ts +9 -0
  52. package/dist/middleware/index.d.ts.map +1 -0
  53. package/dist/middleware/index.js +25 -0
  54. package/dist/middleware/index.js.map +1 -0
  55. package/dist/middleware/internalAuth.d.ts +4 -0
  56. package/dist/middleware/internalAuth.d.ts.map +1 -0
  57. package/dist/middleware/internalAuth.js +23 -0
  58. package/dist/middleware/internalAuth.js.map +1 -0
  59. package/dist/middleware/rateLimiter.d.ts +4 -0
  60. package/dist/middleware/rateLimiter.d.ts.map +1 -0
  61. package/dist/middleware/rateLimiter.js +24 -0
  62. package/dist/middleware/rateLimiter.js.map +1 -0
  63. package/dist/middleware/swagger.d.ts +16 -0
  64. package/dist/middleware/swagger.d.ts.map +1 -0
  65. package/dist/middleware/swagger.js +49 -0
  66. package/dist/middleware/swagger.js.map +1 -0
  67. package/dist/middleware/validation.d.ts +4 -0
  68. package/dist/middleware/validation.d.ts.map +1 -0
  69. package/dist/middleware/validation.js +24 -0
  70. package/dist/middleware/validation.js.map +1 -0
  71. package/dist/types/admin-auth.d.ts +44 -0
  72. package/dist/types/admin-auth.d.ts.map +1 -0
  73. package/dist/types/admin-auth.js +3 -0
  74. package/dist/types/admin-auth.js.map +1 -0
  75. package/dist/types/auth.d.ts +53 -0
  76. package/dist/types/auth.d.ts.map +1 -0
  77. package/dist/types/auth.js +3 -0
  78. package/dist/types/auth.js.map +1 -0
  79. package/dist/types/enums/auth.d.ts +7 -0
  80. package/dist/types/enums/auth.d.ts.map +1 -0
  81. package/dist/types/enums/auth.js +11 -0
  82. package/dist/types/enums/auth.js.map +1 -0
  83. package/dist/types/enums/index.d.ts +2 -0
  84. package/dist/types/enums/index.d.ts.map +1 -0
  85. package/dist/types/enums/index.js +18 -0
  86. package/dist/types/enums/index.js.map +1 -0
  87. package/dist/types/index.d.ts +4 -0
  88. package/dist/types/index.d.ts.map +1 -0
  89. package/dist/types/index.js +20 -0
  90. package/dist/types/index.js.map +1 -0
  91. package/dist/utils/index.d.ts +4 -0
  92. package/dist/utils/index.d.ts.map +1 -0
  93. package/dist/utils/index.js +20 -0
  94. package/dist/utils/index.js.map +1 -0
  95. package/dist/utils/jwt.d.ts +5 -0
  96. package/dist/utils/jwt.d.ts.map +1 -0
  97. package/dist/utils/jwt.js +67 -0
  98. package/dist/utils/jwt.js.map +1 -0
  99. package/dist/utils/logger.d.ts +6 -0
  100. package/dist/utils/logger.d.ts.map +1 -0
  101. package/dist/utils/logger.js +69 -0
  102. package/dist/utils/logger.js.map +1 -0
  103. package/dist/utils/openapi.d.ts +9 -0
  104. package/dist/utils/openapi.d.ts.map +1 -0
  105. package/dist/utils/openapi.js +90 -0
  106. package/dist/utils/openapi.js.map +1 -0
  107. package/dist/utils/validation.d.ts +12 -0
  108. package/dist/utils/validation.d.ts.map +1 -0
  109. package/dist/utils/validation.js +108 -0
  110. package/dist/utils/validation.js.map +1 -0
  111. package/index.ts +4 -0
  112. package/logs/combined.log +85182 -0
  113. package/logs/error.log +48814 -0
  114. package/middleware/admin-auth.ts +93 -0
  115. package/middleware/auth.ts +100 -0
  116. package/middleware/cors.ts +48 -0
  117. package/middleware/errorHandler.ts +62 -0
  118. package/middleware/index.ts +8 -0
  119. package/middleware/internalAuth.ts +25 -0
  120. package/middleware/rateLimiter.ts +18 -0
  121. package/middleware/swagger.ts +69 -0
  122. package/middleware/validation.ts +24 -0
  123. package/package.json +43 -0
  124. package/public/swagger.css +114 -0
  125. package/tsconfig.json +10 -0
  126. package/types/admin-auth.ts +47 -0
  127. package/types/auth.ts +66 -0
  128. package/types/enums/auth.ts +6 -0
  129. package/types/enums/index.ts +1 -0
  130. package/types/index.ts +3 -0
  131. package/utils/index.ts +3 -0
  132. package/utils/jwt.ts +66 -0
  133. package/utils/logger.ts +90 -0
  134. package/utils/openapi.ts +125 -0
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.requireInternalToken = void 0;
4
+ const requireInternalToken = (req, res, next) => {
5
+ if (process.env.ALLOW_DIRECT_ACCESS === 'true') {
6
+ next();
7
+ return;
8
+ }
9
+ const token = process.env.INTERNAL_SERVICE_TOKEN;
10
+ if (!token) {
11
+ res.status(403).json({ success: false, message: 'Internal access token not configured' });
12
+ return;
13
+ }
14
+ const incoming = req.headers['x-internal-token'] || '';
15
+ if (incoming !== token) {
16
+ res.status(403).json({ success: false, message: 'Forbidden' });
17
+ return;
18
+ }
19
+ next();
20
+ };
21
+ exports.requireInternalToken = requireInternalToken;
22
+ exports.default = exports.requireInternalToken;
23
+ //# sourceMappingURL=internalAuth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"internalAuth.js","sourceRoot":"","sources":["../../middleware/internalAuth.ts"],"names":[],"mappings":";;;AAEO,MAAM,oBAAoB,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAQ,EAAE;IAC5F,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,KAAK,MAAM,EAAE,CAAC;QAC/C,IAAI,EAAE,CAAC;QACP,OAAO;IACT,CAAC;IAED,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC;IACjD,IAAI,CAAC,KAAK,EAAE,CAAC;QAEX,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,sCAAsC,EAAE,CAAC,CAAC;QAC1F,OAAO;IACT,CAAC;IAED,MAAM,QAAQ,GAAI,GAAG,CAAC,OAAO,CAAC,kBAAkB,CAAY,IAAI,EAAE,CAAC;IACnE,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;QACvB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC;QAC/D,OAAO;IACT,CAAC;IAED,IAAI,EAAE,CAAC;AACT,CAAC,CAAC;AApBW,QAAA,oBAAoB,wBAoB/B;AAEF,kBAAe,4BAAoB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare const createRateLimiter: (windowMs?: number, max?: number) => import("express-rate-limit").RateLimitRequestHandler;
2
+ export declare const authRateLimiter: import("express-rate-limit").RateLimitRequestHandler;
3
+ export declare const generalRateLimiter: import("express-rate-limit").RateLimitRequestHandler;
4
+ //# sourceMappingURL=rateLimiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rateLimiter.d.ts","sourceRoot":"","sources":["../../middleware/rateLimiter.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,iBAAiB,GAAI,WAAU,MAAuB,EAAE,MAAK,MAAa,yDAYtF,CAAC;AAEF,eAAO,MAAM,eAAe,sDAAuC,CAAC;AACpE,eAAO,MAAM,kBAAkB,sDAA0C,CAAC"}
@@ -0,0 +1,24 @@
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.generalRateLimiter = exports.authRateLimiter = exports.createRateLimiter = void 0;
7
+ const express_rate_limit_1 = __importDefault(require("express-rate-limit"));
8
+ const createRateLimiter = (windowMs = 15 * 60 * 1000, max = 1000) => {
9
+ return (0, express_rate_limit_1.default)({
10
+ windowMs,
11
+ max,
12
+ message: {
13
+ success: false,
14
+ message: 'Too many requests from this IP, please try again later.',
15
+ retryAfter: `${Math.ceil(windowMs / 60000)} minutes`
16
+ },
17
+ standardHeaders: true,
18
+ legacyHeaders: false,
19
+ });
20
+ };
21
+ exports.createRateLimiter = createRateLimiter;
22
+ exports.authRateLimiter = (0, exports.createRateLimiter)(15 * 60 * 1000, 5);
23
+ exports.generalRateLimiter = (0, exports.createRateLimiter)(15 * 60 * 1000, 1000);
24
+ //# sourceMappingURL=rateLimiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rateLimiter.js","sourceRoot":"","sources":["../../middleware/rateLimiter.ts"],"names":[],"mappings":";;;;;;AAAA,4EAA2C;AAEpC,MAAM,iBAAiB,GAAG,CAAC,WAAmB,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,MAAc,IAAI,EAAE,EAAE;IACzF,OAAO,IAAA,4BAAS,EAAC;QACf,QAAQ;QACR,GAAG;QACH,OAAO,EAAE;YACP,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,yDAAyD;YAClE,UAAU,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,UAAU;SACrD;QACD,eAAe,EAAE,IAAI;QACrB,aAAa,EAAE,KAAK;KACrB,CAAC,CAAC;AACL,CAAC,CAAC;AAZW,QAAA,iBAAiB,qBAY5B;AAEW,QAAA,eAAe,GAAG,IAAA,yBAAiB,EAAC,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;AACvD,QAAA,kBAAkB,GAAG,IAAA,yBAAiB,EAAC,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { Express } from 'express';
2
+ type OpenApiSpec = Record<string, unknown>;
3
+ type SwaggerUiUrl = {
4
+ name: string;
5
+ url: string;
6
+ };
7
+ type SwaggerSetupOptions = {
8
+ basePath?: string;
9
+ spec?: OpenApiSpec;
10
+ getSpec?: () => Promise<OpenApiSpec> | OpenApiSpec;
11
+ swaggerUiUrls?: SwaggerUiUrl[];
12
+ swaggerUiPrimaryName?: string;
13
+ };
14
+ export declare const setupSwagger: (app: Express, options?: SwaggerSetupOptions) => void;
15
+ export {};
16
+ //# sourceMappingURL=swagger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"swagger.d.ts","sourceRoot":"","sources":["../../middleware/swagger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAKlC,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAE3C,KAAK,YAAY,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,KAAK,mBAAmB,GAAG;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,WAAW,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,OAAO,CAAC,WAAW,CAAC,GAAG,WAAW,CAAC;IACnD,aAAa,CAAC,EAAE,YAAY,EAAE,CAAC;IAC/B,oBAAoB,CAAC,EAAE,MAAM,CAAC;CAC/B,CAAC;AAcF,eAAO,MAAM,YAAY,GAAI,KAAK,OAAO,EAAE,UAAS,mBAAwB,SAoC3E,CAAC"}
@@ -0,0 +1,49 @@
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.setupSwagger = void 0;
7
+ const swagger_ui_express_1 = __importDefault(require("swagger-ui-express"));
8
+ const swagger_ui_1 = require("../config/swagger-ui");
9
+ const utils_1 = require("../utils");
10
+ const resolveSpec = async (options) => {
11
+ if (options.getSpec) {
12
+ return await options.getSpec();
13
+ }
14
+ if (options.spec) {
15
+ return options.spec;
16
+ }
17
+ return {};
18
+ };
19
+ const setupSwagger = (app, options = {}) => {
20
+ const basePath = options.basePath ?? '/api-docs';
21
+ app.get(`${basePath}/swagger.json`, async (_req, res) => {
22
+ try {
23
+ const spec = await resolveSpec(options);
24
+ res.setHeader('Content-Type', 'application/json');
25
+ res.send(spec);
26
+ }
27
+ catch (error) {
28
+ const err = error instanceof Error ? error : new Error(String(error));
29
+ utils_1.logger.error(`Failed to build swagger spec: ${err.message}`);
30
+ res.status(500).json({ success: false, message: 'Failed to build swagger spec' });
31
+ }
32
+ });
33
+ app.use(basePath, swagger_ui_express_1.default.serve, swagger_ui_express_1.default.setup(undefined, {
34
+ ...swagger_ui_1.swaggerUiOptions,
35
+ swaggerOptions: {
36
+ ...(options.swaggerUiUrls && options.swaggerUiUrls.length > 0
37
+ ? {
38
+ urls: options.swaggerUiUrls,
39
+ ...(options.swaggerUiPrimaryName
40
+ ? { urlsPrimaryName: options.swaggerUiPrimaryName }
41
+ : {}),
42
+ }
43
+ : { url: `${basePath}/swagger.json` }),
44
+ },
45
+ }));
46
+ utils_1.logger.info(`📚 Swagger documentation available at: http://localhost:${process.env.PORT || 4000}${basePath}`);
47
+ };
48
+ exports.setupSwagger = setupSwagger;
49
+ //# sourceMappingURL=swagger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"swagger.js","sourceRoot":"","sources":["../../middleware/swagger.ts"],"names":[],"mappings":";;;;;;AACA,4EAA2C;AAC3C,qDAAwD;AACxD,oCAAkC;AAiBlC,MAAM,WAAW,GAAG,KAAK,EAAE,OAA4B,EAAwB,EAAE;IAC/E,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QACpB,OAAO,MAAM,OAAO,CAAC,OAAO,EAAE,CAAC;IACjC,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,OAAO,OAAO,CAAC,IAAI,CAAC;IACtB,CAAC;IAED,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC;AAEK,MAAM,YAAY,GAAG,CAAC,GAAY,EAAE,UAA+B,EAAE,EAAE,EAAE;IAC9E,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,WAAW,CAAC;IAEjD,GAAG,CAAC,GAAG,CAAC,GAAG,QAAQ,eAAe,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,EAAE;QACtD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC;YACxC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;YAClD,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACtE,cAAM,CAAC,KAAK,CAAC,iCAAiC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YAC7D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,8BAA8B,EAAE,CAAC,CAAC;QACpF,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CACL,QAAQ,EACR,4BAAS,CAAC,KAAK,EACf,4BAAS,CAAC,KAAK,CAAC,SAAS,EAAE;QACzB,GAAG,6BAAgB;QACnB,cAAc,EAAE;YACd,GAAG,CAAC,OAAO,CAAC,aAAa,IAAI,OAAO,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC;gBAC3D,CAAC,CAAC;oBACE,IAAI,EAAE,OAAO,CAAC,aAAa;oBAC3B,GAAG,CAAC,OAAO,CAAC,oBAAoB;wBAC9B,CAAC,CAAC,EAAE,eAAe,EAAE,OAAO,CAAC,oBAAoB,EAAE;wBACnD,CAAC,CAAC,EAAE,CAAC;iBACR;gBACH,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,QAAQ,eAAe,EAAE,CAAC;SACzC;KACF,CAAC,CACH,CAAC;IAEF,cAAM,CAAC,IAAI,CACT,2DAA2D,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,IAAI,GAAG,QAAQ,EAAE,CACjG,CAAC;AACJ,CAAC,CAAC;AApCW,QAAA,YAAY,gBAoCvB"}
@@ -0,0 +1,4 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ import Joi from 'joi';
3
+ export declare const validateRequest: (schema: Joi.ObjectSchema) => (req: Request, res: Response, next: NextFunction) => void;
4
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../middleware/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,GAAG,MAAM,KAAK,CAAC;AAEtB,eAAO,MAAM,eAAe,GAAI,QAAQ,GAAG,CAAC,YAAY,MAC9C,KAAK,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,KAAG,IAmB3D,CAAC"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateRequest = void 0;
4
+ const validateRequest = (schema) => {
5
+ return (req, res, next) => {
6
+ const { error, value } = schema.validate(req.body, {
7
+ abortEarly: false,
8
+ stripUnknown: true
9
+ });
10
+ if (error) {
11
+ const errorMessages = error.details.map(detail => detail.message);
12
+ res.status(400).json({
13
+ success: false,
14
+ message: 'Validation error',
15
+ errors: errorMessages
16
+ });
17
+ return;
18
+ }
19
+ req.body = value;
20
+ next();
21
+ };
22
+ };
23
+ exports.validateRequest = validateRequest;
24
+ //# sourceMappingURL=validation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.js","sourceRoot":"","sources":["../../middleware/validation.ts"],"names":[],"mappings":";;;AAGO,MAAM,eAAe,GAAG,CAAC,MAAwB,EAAE,EAAE;IAC1D,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAQ,EAAE;QAC/D,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE;YACjD,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAClE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBACnB,OAAO,EAAE,KAAK;gBACd,OAAO,EAAE,kBAAkB;gBAC3B,MAAM,EAAE,aAAa;aACtB,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC;QACjB,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC,CAAC;AApBW,QAAA,eAAe,mBAoB1B"}
@@ -0,0 +1,44 @@
1
+ export interface IAdminUser {
2
+ id: string;
3
+ email: string;
4
+ name: string;
5
+ role: string;
6
+ isActive: boolean;
7
+ permissions: string[];
8
+ }
9
+ export interface IPermission {
10
+ id: string;
11
+ name: string;
12
+ description: string;
13
+ module: string;
14
+ action: string;
15
+ }
16
+ export interface IAppRole {
17
+ id: string;
18
+ name: string;
19
+ description: string;
20
+ permissions: string[];
21
+ isActive: boolean;
22
+ usersCount?: number;
23
+ createdAt: Date;
24
+ updatedAt: Date;
25
+ }
26
+ export interface IPaginationQuery {
27
+ page: number;
28
+ limit: number;
29
+ sortBy?: string;
30
+ sortOrder?: "ASC" | "DESC";
31
+ search?: string;
32
+ }
33
+ export interface IApiResponse<T = any> {
34
+ success: boolean;
35
+ data?: T;
36
+ message?: string;
37
+ error?: string;
38
+ meta?: {
39
+ page?: number;
40
+ limit?: number;
41
+ total?: number;
42
+ };
43
+ }
44
+ //# sourceMappingURL=admin-auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin-auth.d.ts","sourceRoot":"","sources":["../../types/admin-auth.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC;IAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,GAAG;IACnC,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,CAAC,EAAE,CAAC,CAAC;IACT,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE;QACL,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,CAAC;CACH"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=admin-auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin-auth.js","sourceRoot":"","sources":["../../types/admin-auth.ts"],"names":[],"mappings":""}
@@ -0,0 +1,53 @@
1
+ import { AccountType } from "./enums";
2
+ export interface JWTPayload {
3
+ id: number;
4
+ email: string;
5
+ phoneNumber: string | null;
6
+ firstName: string;
7
+ lastName: string;
8
+ accountType: string;
9
+ is_active: boolean;
10
+ emailVerified: boolean;
11
+ phoneVerified: boolean;
12
+ tokenVersion?: number;
13
+ tokenType?: 'access' | 'refresh';
14
+ }
15
+ export interface UserAttributes {
16
+ id: number;
17
+ firstName: string;
18
+ lastName: string;
19
+ email: string;
20
+ phoneNumber: string | null;
21
+ password: string;
22
+ accountType: AccountType;
23
+ is_active: boolean;
24
+ emailVerified: boolean;
25
+ emailVerifiedAt?: Date | null;
26
+ phoneVerified: boolean;
27
+ phoneVerifiedAt?: Date | null;
28
+ tokenVersion?: number;
29
+ created_at?: Date;
30
+ updated_at?: Date;
31
+ }
32
+ declare global {
33
+ namespace Express {
34
+ interface Request {
35
+ user?: JWTPayload;
36
+ }
37
+ }
38
+ }
39
+ export interface UserCreationAttributes extends Omit<UserAttributes, 'id' | 'is_active' | 'created_at' | 'updated_at' | 'emailVerified' | 'emailVerifiedAt' | 'phoneVerified' | 'phoneVerifiedAt'> {
40
+ }
41
+ export interface AuthResponse {
42
+ success: boolean;
43
+ message: string;
44
+ data?: {
45
+ user: Omit<UserAttributes, 'password'>;
46
+ tokens: {
47
+ access_token: string;
48
+ refresh_token: string;
49
+ };
50
+ };
51
+ error?: string;
52
+ }
53
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../types/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,aAAa,EAAE,OAAO,CAAC;IACvB,aAAa,EAAE,OAAO,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,QAAQ,GAAG,SAAS,CAAC;CAClC;AAED,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,WAAW,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,aAAa,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAC9B,aAAa,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,IAAI,CAAC;IAClB,UAAU,CAAC,EAAE,IAAI,CAAC;CACnB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,OAAO,CAAC;QAChB,UAAU,OAAO;YACf,IAAI,CAAC,EAAE,UAAU,CAAC;SACnB;KACF;CACF;AAED,MAAM,WAAW,sBAAuB,SAAQ,IAAI,CAClD,cAAc,EACZ,IAAI,GACJ,WAAW,GACX,YAAY,GACZ,YAAY,GACZ,eAAe,GACf,iBAAiB,GACjB,eAAe,GACf,iBAAiB,CACpB;CAAG;AAEJ,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE;QACL,IAAI,EAAE,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;QACvC,MAAM,EAAE;YACN,YAAY,EAAE,MAAM,CAAC;YACrB,aAAa,EAAE,MAAM,CAAC;SACvB,CAAC;KACH,CAAC;IACF,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../../types/auth.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ export declare enum AccountType {
2
+ Client = "Client",
3
+ Provider = "Provider",
4
+ Admin = "Admin",
5
+ SuperAdmin = "SuperAdmin"
6
+ }
7
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../../types/enums/auth.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,KAAK,UAAU;IACf,UAAU,eAAe;CAC1B"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccountType = void 0;
4
+ var AccountType;
5
+ (function (AccountType) {
6
+ AccountType["Client"] = "Client";
7
+ AccountType["Provider"] = "Provider";
8
+ AccountType["Admin"] = "Admin";
9
+ AccountType["SuperAdmin"] = "SuperAdmin";
10
+ })(AccountType || (exports.AccountType = AccountType = {}));
11
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../types/enums/auth.ts"],"names":[],"mappings":";;;AAAA,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,gCAAiB,CAAA;IACjB,oCAAqB,CAAA;IACrB,8BAAe,CAAA;IACf,wCAAyB,CAAA;AAC3B,CAAC,EALW,WAAW,2BAAX,WAAW,QAKtB"}
@@ -0,0 +1,2 @@
1
+ export * from './auth';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../types/enums/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC"}
@@ -0,0 +1,18 @@
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
+ __exportStar(require("./auth"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../types/enums/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB"}
@@ -0,0 +1,4 @@
1
+ export * from "./auth";
2
+ export * from "./admin-auth";
3
+ export * from "./enums";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../types/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,cAAc,CAAA;AAC5B,cAAc,SAAS,CAAA"}
@@ -0,0 +1,20 @@
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
+ __exportStar(require("./auth"), exports);
18
+ __exportStar(require("./admin-auth"), exports);
19
+ __exportStar(require("./enums"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAsB;AACtB,+CAA4B;AAC5B,0CAAuB"}
@@ -0,0 +1,4 @@
1
+ export * from './jwt';
2
+ export * from './logger';
3
+ export * from './openapi';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC"}
@@ -0,0 +1,20 @@
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
+ __exportStar(require("./jwt"), exports);
18
+ __exportStar(require("./logger"), exports);
19
+ __exportStar(require("./openapi"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAsB;AACtB,2CAAyB;AACzB,4CAA0B"}
@@ -0,0 +1,5 @@
1
+ import { JWTPayload, UserAttributes } from '../types/auth';
2
+ export declare const generateToken: (user: UserAttributes) => string;
3
+ export declare const verifyToken: (token: string) => JWTPayload;
4
+ export declare const generateRefreshToken: (user: UserAttributes) => string;
5
+ //# sourceMappingURL=jwt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.d.ts","sourceRoot":"","sources":["../../utils/jwt.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAK3D,eAAO,MAAM,aAAa,GAAI,MAAM,cAAc,KAAG,MAsBpD,CAAC;AAEF,eAAO,MAAM,WAAW,GAAI,OAAO,MAAM,KAAG,UAW3C,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,MAAM,cAAc,KAAG,MAsB3D,CAAC"}
@@ -0,0 +1,67 @@
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.generateRefreshToken = exports.verifyToken = exports.generateToken = void 0;
7
+ const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
8
+ const JWT_SECRET = process.env.JWT_SECRET || 'your-super-secret-jwt-key-change-in-production';
9
+ const JWT_EXPIRES_IN = process.env.JWT_EXPIRES_IN || '7d';
10
+ const generateToken = (user) => {
11
+ const payload = {
12
+ id: user.id,
13
+ email: user.email,
14
+ phoneNumber: user.phoneNumber,
15
+ firstName: user.firstName,
16
+ lastName: user.lastName,
17
+ accountType: user.accountType,
18
+ is_active: user.is_active,
19
+ emailVerified: user.emailVerified,
20
+ phoneVerified: user.phoneVerified,
21
+ tokenVersion: user.tokenVersion ?? 0,
22
+ tokenType: 'access',
23
+ };
24
+ const options = {
25
+ expiresIn: JWT_EXPIRES_IN,
26
+ issuer: 'ggcoach-auth-service',
27
+ audience: 'ggcoach-app'
28
+ };
29
+ return jsonwebtoken_1.default.sign(payload, JWT_SECRET, options);
30
+ };
31
+ exports.generateToken = generateToken;
32
+ const verifyToken = (token) => {
33
+ try {
34
+ const decoded = jsonwebtoken_1.default.verify(token, JWT_SECRET, {
35
+ issuer: 'ggcoach-auth-service',
36
+ audience: 'ggcoach-app'
37
+ });
38
+ return decoded;
39
+ }
40
+ catch (error) {
41
+ throw new Error('Invalid or expired token');
42
+ }
43
+ };
44
+ exports.verifyToken = verifyToken;
45
+ const generateRefreshToken = (user) => {
46
+ const payload = {
47
+ id: user.id,
48
+ email: user.email,
49
+ phoneNumber: user.phoneNumber,
50
+ firstName: user.firstName,
51
+ lastName: user.lastName,
52
+ accountType: user.accountType,
53
+ is_active: user.is_active,
54
+ emailVerified: user.emailVerified,
55
+ phoneVerified: user.phoneVerified,
56
+ tokenVersion: user.tokenVersion ?? 0,
57
+ tokenType: 'refresh',
58
+ };
59
+ const options = {
60
+ expiresIn: '30d',
61
+ issuer: 'ggcoach-auth-service',
62
+ audience: 'ggcoach-app'
63
+ };
64
+ return jsonwebtoken_1.default.sign(payload, JWT_SECRET, options);
65
+ };
66
+ exports.generateRefreshToken = generateRefreshToken;
67
+ //# sourceMappingURL=jwt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.js","sourceRoot":"","sources":["../../utils/jwt.ts"],"names":[],"mappings":";;;;;;AAAA,gEAA+B;AAG/B,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,gDAAgD,CAAC;AAC9F,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,IAAI,CAAC;AAEnD,MAAM,aAAa,GAAG,CAAC,IAAoB,EAAU,EAAE;IAC5D,MAAM,OAAO,GAAe;QAC1B,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,aAAa,EAAE,IAAI,CAAC,aAAa;QACjC,aAAa,EAAE,IAAI,CAAC,aAAa;QACjC,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,CAAC;QACpC,SAAS,EAAE,QAAQ;KACpB,CAAC;IAEF,MAAM,OAAO,GAAoB;QAC/B,SAAS,EAAE,cAAc;QACzB,MAAM,EAAE,sBAAsB;QAC9B,QAAQ,EAAE,aAAa;KACL,CAAC;IAErB,OAAO,sBAAG,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;AAChD,CAAC,CAAC;AAtBW,QAAA,aAAa,iBAsBxB;AAEK,MAAM,WAAW,GAAG,CAAC,KAAa,EAAc,EAAE;IACvD,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,sBAAG,CAAC,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE;YAC5C,MAAM,EAAE,sBAAsB;YAC9B,QAAQ,EAAE,aAAa;SACxB,CAAe,CAAC;QAEjB,OAAO,OAAO,CAAC;IACjB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAC9C,CAAC;AACH,CAAC,CAAC;AAXW,QAAA,WAAW,eAWtB;AAEK,MAAM,oBAAoB,GAAG,CAAC,IAAoB,EAAU,EAAE;IACnE,MAAM,OAAO,GAAe;QAC1B,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,KAAK,EAAE,IAAI,CAAC,KAAK;QACjB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;QACvB,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,aAAa,EAAE,IAAI,CAAC,aAAa;QACjC,aAAa,EAAE,IAAI,CAAC,aAAa;QACjC,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,CAAC;QACpC,SAAS,EAAE,SAAS;KACrB,CAAC;IAEF,MAAM,OAAO,GAAoB;QAC/B,SAAS,EAAE,KAAK;QAChB,MAAM,EAAE,sBAAsB;QAC9B,QAAQ,EAAE,aAAa;KACL,CAAC;IAErB,OAAO,sBAAG,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;AAChD,CAAC,CAAC;AAtBW,QAAA,oBAAoB,wBAsB/B"}
@@ -0,0 +1,6 @@
1
+ import winston from 'winston';
2
+ export declare const logger: winston.Logger;
3
+ export declare const stream: {
4
+ write: (message: string) => void;
5
+ };
6
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../utils/logger.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAyE9B,eAAO,MAAM,MAAM,gBAKjB,CAAC;AAKH,eAAO,MAAM,MAAM;qBACA,MAAM;CAIxB,CAAC"}
@@ -0,0 +1,69 @@
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.stream = exports.logger = void 0;
7
+ const winston_1 = __importDefault(require("winston"));
8
+ const path_1 = __importDefault(require("path"));
9
+ const fs_1 = __importDefault(require("fs"));
10
+ const logsDir = path_1.default.resolve(__dirname, '..', '..', 'logs');
11
+ if (!fs_1.default.existsSync(logsDir)) {
12
+ try {
13
+ fs_1.default.mkdirSync(logsDir, { recursive: true });
14
+ }
15
+ catch (err) {
16
+ console.warn('Could not create logs directory:', err);
17
+ }
18
+ }
19
+ const customLevels = {
20
+ levels: {
21
+ crit: 0,
22
+ error: 1,
23
+ warn: 2,
24
+ info: 3
25
+ },
26
+ colors: {
27
+ crit: 'magenta',
28
+ error: 'red',
29
+ warn: 'yellow',
30
+ info: 'green'
31
+ }
32
+ };
33
+ const { combine, timestamp, printf, colorize } = winston_1.default.format;
34
+ const logFormat = printf(({ level, message, timestamp: ts, ...meta }) => {
35
+ const metaString = Object.keys(meta).length ? ` ${JSON.stringify(meta)}` : '';
36
+ return `${ts} [${level}]: ${message}${metaString}`;
37
+ });
38
+ const transports = [];
39
+ transports.push(new winston_1.default.transports.Console({
40
+ format: combine(colorize({ all: true }), timestamp(), logFormat)
41
+ }));
42
+ try {
43
+ transports.push(new winston_1.default.transports.File({
44
+ filename: path_1.default.join(logsDir, 'error.log'),
45
+ level: 'error',
46
+ format: combine(timestamp(), logFormat)
47
+ }));
48
+ transports.push(new winston_1.default.transports.File({
49
+ filename: path_1.default.join(logsDir, 'combined.log'),
50
+ level: 'info',
51
+ format: combine(timestamp(), logFormat)
52
+ }));
53
+ }
54
+ catch (err) {
55
+ console.warn('File transports unavailable, using console only for logging.');
56
+ }
57
+ exports.logger = winston_1.default.createLogger({
58
+ levels: customLevels.levels,
59
+ level: process.env.LOG_LEVEL || 'info',
60
+ transports,
61
+ exitOnError: false
62
+ });
63
+ winston_1.default.addColors(customLevels.colors);
64
+ exports.stream = {
65
+ write: (message) => {
66
+ exports.logger.info(message.trim());
67
+ }
68
+ };
69
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../utils/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { Express } from 'express';
2
+ type OpenApiSpec = Record<string, unknown>;
3
+ type TagResolver = (path: string, method: string) => string[] | undefined;
4
+ type BuildOptions = {
5
+ tagResolver?: TagResolver;
6
+ };
7
+ export declare const buildOpenApiSpecFromExpress: (app: Express, baseSpec: OpenApiSpec, options?: BuildOptions) => OpenApiSpec;
8
+ export {};
9
+ //# sourceMappingURL=openapi.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openapi.d.ts","sourceRoot":"","sources":["../../utils/openapi.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAGlC,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAG3C,KAAK,WAAW,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,MAAM,EAAE,GAAG,SAAS,CAAC;AAE1E,KAAK,YAAY,GAAG;IAClB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC;AAmGF,eAAO,MAAM,2BAA2B,GACtC,KAAK,OAAO,EACZ,UAAU,WAAW,EACrB,UAAS,YAAiB,KACzB,WAWF,CAAC"}