@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.
- package/config/config.ts +7 -0
- package/config/index.ts +2 -0
- package/config/initExpress.ts +27 -0
- package/config/redis.ts +38 -0
- package/config/swagger-ui.ts +84 -0
- package/config/swagger.ts +4417 -0
- package/dist/config/config.d.ts +8 -0
- package/dist/config/config.d.ts.map +1 -0
- package/dist/config/config.js +11 -0
- package/dist/config/config.js.map +1 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +19 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/initExpress.d.ts +2 -0
- package/dist/config/initExpress.d.ts.map +1 -0
- package/dist/config/initExpress.js +29 -0
- package/dist/config/initExpress.js.map +1 -0
- package/dist/config/redis.d.ts +6 -0
- package/dist/config/redis.d.ts.map +1 -0
- package/dist/config/redis.js +34 -0
- package/dist/config/redis.js.map +1 -0
- package/dist/config/swagger-ui.d.ts +6 -0
- package/dist/config/swagger-ui.d.ts.map +1 -0
- package/dist/config/swagger-ui.js +88 -0
- package/dist/config/swagger-ui.js.map +1 -0
- package/dist/config/swagger.d.ts +9 -0
- package/dist/config/swagger.d.ts.map +1 -0
- package/dist/config/swagger.js +4406 -0
- package/dist/config/swagger.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/admin-auth.d.ts +4 -0
- package/dist/middleware/admin-auth.d.ts.map +1 -0
- package/dist/middleware/admin-auth.js +55 -0
- package/dist/middleware/admin-auth.js.map +1 -0
- package/dist/middleware/auth.d.ts +4 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.js +86 -0
- package/dist/middleware/auth.js.map +1 -0
- package/dist/middleware/cors.d.ts +16 -0
- package/dist/middleware/cors.d.ts.map +1 -0
- package/dist/middleware/cors.js +45 -0
- package/dist/middleware/cors.js.map +1 -0
- package/dist/middleware/errorHandler.d.ts +3 -0
- package/dist/middleware/errorHandler.d.ts.map +1 -0
- package/dist/middleware/errorHandler.js +58 -0
- package/dist/middleware/errorHandler.js.map +1 -0
- package/dist/middleware/index.d.ts +9 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +25 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/internalAuth.d.ts +4 -0
- package/dist/middleware/internalAuth.d.ts.map +1 -0
- package/dist/middleware/internalAuth.js +23 -0
- package/dist/middleware/internalAuth.js.map +1 -0
- package/dist/middleware/rateLimiter.d.ts +4 -0
- package/dist/middleware/rateLimiter.d.ts.map +1 -0
- package/dist/middleware/rateLimiter.js +24 -0
- package/dist/middleware/rateLimiter.js.map +1 -0
- package/dist/middleware/swagger.d.ts +16 -0
- package/dist/middleware/swagger.d.ts.map +1 -0
- package/dist/middleware/swagger.js +49 -0
- package/dist/middleware/swagger.js.map +1 -0
- package/dist/middleware/validation.d.ts +4 -0
- package/dist/middleware/validation.d.ts.map +1 -0
- package/dist/middleware/validation.js +24 -0
- package/dist/middleware/validation.js.map +1 -0
- package/dist/types/admin-auth.d.ts +44 -0
- package/dist/types/admin-auth.d.ts.map +1 -0
- package/dist/types/admin-auth.js +3 -0
- package/dist/types/admin-auth.js.map +1 -0
- package/dist/types/auth.d.ts +53 -0
- package/dist/types/auth.d.ts.map +1 -0
- package/dist/types/auth.js +3 -0
- package/dist/types/auth.js.map +1 -0
- package/dist/types/enums/auth.d.ts +7 -0
- package/dist/types/enums/auth.d.ts.map +1 -0
- package/dist/types/enums/auth.js +11 -0
- package/dist/types/enums/auth.js.map +1 -0
- package/dist/types/enums/index.d.ts +2 -0
- package/dist/types/enums/index.d.ts.map +1 -0
- package/dist/types/enums/index.js +18 -0
- package/dist/types/enums/index.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +20 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +20 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/jwt.d.ts +5 -0
- package/dist/utils/jwt.d.ts.map +1 -0
- package/dist/utils/jwt.js +67 -0
- package/dist/utils/jwt.js.map +1 -0
- package/dist/utils/logger.d.ts +6 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +69 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/openapi.d.ts +9 -0
- package/dist/utils/openapi.d.ts.map +1 -0
- package/dist/utils/openapi.js +90 -0
- package/dist/utils/openapi.js.map +1 -0
- package/dist/utils/validation.d.ts +12 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +108 -0
- package/dist/utils/validation.js.map +1 -0
- package/index.ts +4 -0
- package/logs/combined.log +85182 -0
- package/logs/error.log +48814 -0
- package/middleware/admin-auth.ts +93 -0
- package/middleware/auth.ts +100 -0
- package/middleware/cors.ts +48 -0
- package/middleware/errorHandler.ts +62 -0
- package/middleware/index.ts +8 -0
- package/middleware/internalAuth.ts +25 -0
- package/middleware/rateLimiter.ts +18 -0
- package/middleware/swagger.ts +69 -0
- package/middleware/validation.ts +24 -0
- package/package.json +43 -0
- package/public/swagger.css +114 -0
- package/tsconfig.json +10 -0
- package/types/admin-auth.ts +47 -0
- package/types/auth.ts +66 -0
- package/types/enums/auth.ts +6 -0
- package/types/enums/index.ts +1 -0
- package/types/index.ts +3 -0
- package/utils/index.ts +3 -0
- package/utils/jwt.ts +66 -0
- package/utils/logger.ts +90 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../types/auth.ts"],"names":[],"mappings":""}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|