@fabx.vn/core 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 (171) hide show
  1. package/README.md +270 -0
  2. package/dist/config/cookie.config.d.ts +3 -0
  3. package/dist/config/cookie.config.js +7 -0
  4. package/dist/config/cookie.config.js.map +1 -0
  5. package/dist/config/cors.config.d.ts +6 -0
  6. package/dist/config/cors.config.js +15 -0
  7. package/dist/config/cors.config.js.map +1 -0
  8. package/dist/config/database.config.d.ts +13 -0
  9. package/dist/config/database.config.js +17 -0
  10. package/dist/config/database.config.js.map +1 -0
  11. package/dist/config/google-oauth.config.d.ts +6 -0
  12. package/dist/config/google-oauth.config.js +10 -0
  13. package/dist/config/google-oauth.config.js.map +1 -0
  14. package/dist/config/internal.config.d.ts +8 -0
  15. package/dist/config/internal.config.js +15 -0
  16. package/dist/config/internal.config.js.map +1 -0
  17. package/dist/config/jwt.config.d.ts +5 -0
  18. package/dist/config/jwt.config.js +9 -0
  19. package/dist/config/jwt.config.js.map +1 -0
  20. package/dist/config/rabbitmq.config.d.ts +19 -0
  21. package/dist/config/rabbitmq.config.js +25 -0
  22. package/dist/config/rabbitmq.config.js.map +1 -0
  23. package/dist/config/redis.config.d.ts +9 -0
  24. package/dist/config/redis.config.js +13 -0
  25. package/dist/config/redis.config.js.map +1 -0
  26. package/dist/constants/http-status.constants.d.ts +106 -0
  27. package/dist/constants/http-status.constants.js +110 -0
  28. package/dist/constants/http-status.constants.js.map +1 -0
  29. package/dist/constants/messages.constants.d.ts +112 -0
  30. package/dist/constants/messages.constants.js +116 -0
  31. package/dist/constants/messages.constants.js.map +1 -0
  32. package/dist/core/core.module.d.ts +2 -0
  33. package/dist/core/core.module.js +72 -0
  34. package/dist/core/core.module.js.map +1 -0
  35. package/dist/core/decorators/current-user.decorator.d.ts +1 -0
  36. package/dist/core/decorators/current-user.decorator.js +9 -0
  37. package/dist/core/decorators/current-user.decorator.js.map +1 -0
  38. package/dist/core/decorators/public.decorator.d.ts +2 -0
  39. package/dist/core/decorators/public.decorator.js +8 -0
  40. package/dist/core/decorators/public.decorator.js.map +1 -0
  41. package/dist/core/decorators/require-permissions.decorator.d.ts +4 -0
  42. package/dist/core/decorators/require-permissions.decorator.js +11 -0
  43. package/dist/core/decorators/require-permissions.decorator.js.map +1 -0
  44. package/dist/core/dtos/api-response.dto.d.ts +10 -0
  45. package/dist/core/dtos/api-response.dto.js +22 -0
  46. package/dist/core/dtos/api-response.dto.js.map +1 -0
  47. package/dist/core/dtos/pagination.dto.d.ts +17 -0
  48. package/dist/core/dtos/pagination.dto.js +61 -0
  49. package/dist/core/dtos/pagination.dto.js.map +1 -0
  50. package/dist/core/filters/http-exception.filter.d.ts +5 -0
  51. package/dist/core/filters/http-exception.filter.js +47 -0
  52. package/dist/core/filters/http-exception.filter.js.map +1 -0
  53. package/dist/core/guards/internal-auth.guard.d.ts +7 -0
  54. package/dist/core/guards/internal-auth.guard.js +42 -0
  55. package/dist/core/guards/internal-auth.guard.js.map +1 -0
  56. package/dist/core/guards/jwt-auth.guard.d.ts +12 -0
  57. package/dist/core/guards/jwt-auth.guard.js +56 -0
  58. package/dist/core/guards/jwt-auth.guard.js.map +1 -0
  59. package/dist/core/guards/permission.guard.d.ts +9 -0
  60. package/dist/core/guards/permission.guard.js +71 -0
  61. package/dist/core/guards/permission.guard.js.map +1 -0
  62. package/dist/core/interceptors/request-context.interceptor.d.ts +8 -0
  63. package/dist/core/interceptors/request-context.interceptor.js +39 -0
  64. package/dist/core/interceptors/request-context.interceptor.js.map +1 -0
  65. package/dist/core/services/cache.service.d.ts +13 -0
  66. package/dist/core/services/cache.service.js +51 -0
  67. package/dist/core/services/cache.service.js.map +1 -0
  68. package/dist/core/services/cookie.service.d.ts +13 -0
  69. package/dist/core/services/cookie.service.js +50 -0
  70. package/dist/core/services/cookie.service.js.map +1 -0
  71. package/dist/core/services/jwt.service.d.ts +37 -0
  72. package/dist/core/services/jwt.service.js +187 -0
  73. package/dist/core/services/jwt.service.js.map +1 -0
  74. package/dist/core/services/permission.service.d.ts +23 -0
  75. package/dist/core/services/permission.service.js +83 -0
  76. package/dist/core/services/permission.service.js.map +1 -0
  77. package/dist/core/services/rabbitmq-publisher.service.d.ts +9 -0
  78. package/dist/core/services/rabbitmq-publisher.service.js +57 -0
  79. package/dist/core/services/rabbitmq-publisher.service.js.map +1 -0
  80. package/dist/core/services/redis.service.d.ts +18 -0
  81. package/dist/core/services/redis.service.js +66 -0
  82. package/dist/core/services/redis.service.js.map +1 -0
  83. package/dist/core/services/request-context.service.d.ts +18 -0
  84. package/dist/core/services/request-context.service.js +40 -0
  85. package/dist/core/services/request-context.service.js.map +1 -0
  86. package/dist/core/services/request-info.service.d.ts +8 -0
  87. package/dist/core/services/request-info.service.js +32 -0
  88. package/dist/core/services/request-info.service.js.map +1 -0
  89. package/dist/core/services/session.service.d.ts +21 -0
  90. package/dist/core/services/session.service.js +70 -0
  91. package/dist/core/services/session.service.js.map +1 -0
  92. package/dist/core/strategies/jwt.strategy.d.ts +7 -0
  93. package/dist/core/strategies/jwt.strategy.js +38 -0
  94. package/dist/core/strategies/jwt.strategy.js.map +1 -0
  95. package/dist/core/subscribers/audit.subscriber.d.ts +8 -0
  96. package/dist/core/subscribers/audit.subscriber.js +40 -0
  97. package/dist/core/subscribers/audit.subscriber.js.map +1 -0
  98. package/dist/core.module.d.ts +2 -0
  99. package/dist/core.module.js +72 -0
  100. package/dist/core.module.js.map +1 -0
  101. package/dist/decorators/current-user.decorator.d.ts +1 -0
  102. package/dist/decorators/current-user.decorator.js +9 -0
  103. package/dist/decorators/current-user.decorator.js.map +1 -0
  104. package/dist/decorators/public.decorator.d.ts +2 -0
  105. package/dist/decorators/public.decorator.js +8 -0
  106. package/dist/decorators/public.decorator.js.map +1 -0
  107. package/dist/decorators/require-permissions.decorator.d.ts +4 -0
  108. package/dist/decorators/require-permissions.decorator.js +11 -0
  109. package/dist/decorators/require-permissions.decorator.js.map +1 -0
  110. package/dist/dtos/api-response.dto.d.ts +10 -0
  111. package/dist/dtos/api-response.dto.js +22 -0
  112. package/dist/dtos/api-response.dto.js.map +1 -0
  113. package/dist/dtos/pagination.dto.d.ts +17 -0
  114. package/dist/dtos/pagination.dto.js +61 -0
  115. package/dist/dtos/pagination.dto.js.map +1 -0
  116. package/dist/filters/http-exception.filter.d.ts +5 -0
  117. package/dist/filters/http-exception.filter.js +47 -0
  118. package/dist/filters/http-exception.filter.js.map +1 -0
  119. package/dist/guards/internal-auth.guard.d.ts +7 -0
  120. package/dist/guards/internal-auth.guard.js +42 -0
  121. package/dist/guards/internal-auth.guard.js.map +1 -0
  122. package/dist/guards/jwt-auth.guard.d.ts +12 -0
  123. package/dist/guards/jwt-auth.guard.js +56 -0
  124. package/dist/guards/jwt-auth.guard.js.map +1 -0
  125. package/dist/guards/permission.guard.d.ts +9 -0
  126. package/dist/guards/permission.guard.js +71 -0
  127. package/dist/guards/permission.guard.js.map +1 -0
  128. package/dist/index.d.ts +33 -0
  129. package/dist/index.js +80 -0
  130. package/dist/index.js.map +1 -0
  131. package/dist/interceptors/request-context.interceptor.d.ts +8 -0
  132. package/dist/interceptors/request-context.interceptor.js +39 -0
  133. package/dist/interceptors/request-context.interceptor.js.map +1 -0
  134. package/dist/libs/axios/axios-client.d.ts +8 -0
  135. package/dist/libs/axios/axios-client.js +61 -0
  136. package/dist/libs/axios/axios-client.js.map +1 -0
  137. package/dist/libs/axios/index.d.ts +1 -0
  138. package/dist/libs/axios/index.js +8 -0
  139. package/dist/libs/axios/index.js.map +1 -0
  140. package/dist/services/cookie.service.d.ts +13 -0
  141. package/dist/services/cookie.service.js +50 -0
  142. package/dist/services/cookie.service.js.map +1 -0
  143. package/dist/services/jwt.service.d.ts +37 -0
  144. package/dist/services/jwt.service.js +187 -0
  145. package/dist/services/jwt.service.js.map +1 -0
  146. package/dist/services/rabbitmq-publisher.service.d.ts +9 -0
  147. package/dist/services/rabbitmq-publisher.service.js +57 -0
  148. package/dist/services/rabbitmq-publisher.service.js.map +1 -0
  149. package/dist/services/redis.service.d.ts +18 -0
  150. package/dist/services/redis.service.js +66 -0
  151. package/dist/services/redis.service.js.map +1 -0
  152. package/dist/services/request-context.service.d.ts +18 -0
  153. package/dist/services/request-context.service.js +40 -0
  154. package/dist/services/request-context.service.js.map +1 -0
  155. package/dist/services/request-info.service.d.ts +8 -0
  156. package/dist/services/request-info.service.js +32 -0
  157. package/dist/services/request-info.service.js.map +1 -0
  158. package/dist/services/session.service.d.ts +21 -0
  159. package/dist/services/session.service.js +70 -0
  160. package/dist/services/session.service.js.map +1 -0
  161. package/dist/strategies/jwt.strategy.d.ts +7 -0
  162. package/dist/strategies/jwt.strategy.js +38 -0
  163. package/dist/strategies/jwt.strategy.js.map +1 -0
  164. package/dist/subscribers/audit.subscriber.d.ts +8 -0
  165. package/dist/subscribers/audit.subscriber.js +40 -0
  166. package/dist/subscribers/audit.subscriber.js.map +1 -0
  167. package/dist/tsconfig.tsbuildinfo +1 -0
  168. package/dist/utils/date.utils.d.ts +4 -0
  169. package/dist/utils/date.utils.js +52 -0
  170. package/dist/utils/date.utils.js.map +1 -0
  171. package/package.json +52 -0
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.SessionService = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const crypto_1 = require("crypto");
15
+ const redis_service_1 = require("./redis.service");
16
+ let SessionService = class SessionService {
17
+ constructor(redisService) {
18
+ this.redisService = redisService;
19
+ }
20
+ async createSession(data, ttlSec) {
21
+ const sid = (0, crypto_1.randomUUID)();
22
+ const key = `session:${sid}`;
23
+ await this.redisService.setWithOptions(key, JSON.stringify(data), "EX", ttlSec);
24
+ if (data.userId) {
25
+ await this.redisService.sadd(`user_sessions:${data.userId}`, sid);
26
+ await this.redisService.expire(`user_sessions:${data.userId}`, ttlSec);
27
+ }
28
+ return sid;
29
+ }
30
+ async getSession(sid) {
31
+ const key = `session:${sid}`;
32
+ const json = await this.redisService.get(key);
33
+ if (!json)
34
+ return null;
35
+ return JSON.parse(json);
36
+ }
37
+ async extendSession(sid, ttlSec) {
38
+ const key = `session:${sid}`;
39
+ const res = await this.redisService.expire(key, ttlSec);
40
+ return res === 1;
41
+ }
42
+ async deleteSession(sid) {
43
+ const key = `session:${sid}`;
44
+ const json = await this.redisService.get(key);
45
+ if (json) {
46
+ const data = JSON.parse(json);
47
+ if (data.userId) {
48
+ await this.redisService.srem(`user_sessions:${data.userId}`, sid);
49
+ }
50
+ }
51
+ return this.redisService.del(key);
52
+ }
53
+ async revokeAllForUser(userId) {
54
+ const setKey = `user_sessions:${userId}`;
55
+ const sids = await this.redisService.smembers(setKey);
56
+ if (sids.length) {
57
+ const pipeline = this.redisService.pipeline();
58
+ sids.forEach((sid) => pipeline.del(`session:${sid}`));
59
+ pipeline.del(setKey);
60
+ await pipeline.exec();
61
+ }
62
+ return true;
63
+ }
64
+ };
65
+ exports.SessionService = SessionService;
66
+ exports.SessionService = SessionService = __decorate([
67
+ (0, common_1.Injectable)(),
68
+ __metadata("design:paramtypes", [redis_service_1.RedisService])
69
+ ], SessionService);
70
+ //# sourceMappingURL=session.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.service.js","sourceRoot":"","sources":["../../../src/core/services/session.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { CurrentUserDto } from "@core/services/session.service";
2
+ declare const JwtStrategy_base: new (...args: any[]) => any;
3
+ export declare class JwtStrategy extends JwtStrategy_base {
4
+ constructor();
5
+ validate(payload: any): Promise<CurrentUserDto>;
6
+ }
7
+ export {};
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.JwtStrategy = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const passport_1 = require("@nestjs/passport");
15
+ const passport_jwt_1 = require("passport-jwt");
16
+ const jwt_config_1 = require("@config/jwt.config");
17
+ const cookie_service_1 = require("@core/services/cookie.service");
18
+ let JwtStrategy = class JwtStrategy extends (0, passport_1.PassportStrategy)(passport_jwt_1.Strategy) {
19
+ constructor() {
20
+ super({
21
+ jwtFromRequest: passport_jwt_1.ExtractJwt.fromExtractors([
22
+ (req) => cookie_service_1.CookieService.extractTokensFromCookie(req)?.accessToken || null,
23
+ ]),
24
+ ignoreExpiration: false,
25
+ secretOrKey: jwt_config_1.jwtConfig.secret,
26
+ algorithms: ["HS256"],
27
+ });
28
+ }
29
+ async validate(payload) {
30
+ return payload;
31
+ }
32
+ };
33
+ exports.JwtStrategy = JwtStrategy;
34
+ exports.JwtStrategy = JwtStrategy = __decorate([
35
+ (0, common_1.Injectable)(),
36
+ __metadata("design:paramtypes", [])
37
+ ], JwtStrategy);
38
+ //# sourceMappingURL=jwt.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.strategy.js","sourceRoot":"","sources":["../../../src/core/strategies/jwt.strategy.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,+CAAoD;AACpD,+CAAoD;AACpD,mDAA+C;AAE/C,kEAA8D;AAIvD,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,IAAA,2BAAgB,EAAC,uBAAQ,CAAC;IACzD;QACE,KAAK,CAAC;YACJ,cAAc,EAAE,yBAAU,CAAC,cAAc,CAAC;gBACxC,CAAC,GAAY,EAAE,EAAE,CACf,8BAAa,CAAC,uBAAuB,CAAC,GAAG,CAAC,EAAE,WAAW,IAAI,IAAI;aAClE,CAAC;YACF,gBAAgB,EAAE,KAAK;YACvB,WAAW,EAAE,sBAAS,CAAC,MAAM;YAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;SACtB,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,OAAY;QACzB,OAAO,OAAyB,CAAC;IACnC,CAAC;CACF,CAAA;AAhBY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;;GACA,WAAW,CAgBvB"}
@@ -0,0 +1,8 @@
1
+ import { DataSource, EntitySubscriberInterface, InsertEvent, UpdateEvent } from "typeorm";
2
+ export declare class AuditSubscriber implements EntitySubscriberInterface {
3
+ private dataSource;
4
+ constructor(dataSource: DataSource);
5
+ private enrichEntity;
6
+ beforeInsert(event: InsertEvent<any>): void;
7
+ beforeUpdate(event: UpdateEvent<any>): void;
8
+ }
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.AuditSubscriber = void 0;
13
+ const typeorm_1 = require("typeorm");
14
+ const common_1 = require("@nestjs/common");
15
+ const request_context_service_1 = require("@core/services/request-context.service");
16
+ let AuditSubscriber = class AuditSubscriber {
17
+ constructor(dataSource) {
18
+ this.dataSource = dataSource;
19
+ this.dataSource.subscribers.push(this);
20
+ }
21
+ enrichEntity(entity, context) {
22
+ }
23
+ beforeInsert(event) {
24
+ const context = request_context_service_1.RequestContextService.getCurrentContext();
25
+ if (context && event.entity)
26
+ this.enrichEntity(event.entity, context);
27
+ }
28
+ beforeUpdate(event) {
29
+ const context = request_context_service_1.RequestContextService.getCurrentContext();
30
+ if (context && event.entity)
31
+ this.enrichEntity(event.entity, context);
32
+ }
33
+ };
34
+ exports.AuditSubscriber = AuditSubscriber;
35
+ exports.AuditSubscriber = AuditSubscriber = __decorate([
36
+ (0, common_1.Injectable)(),
37
+ (0, typeorm_1.EventSubscriber)(),
38
+ __metadata("design:paramtypes", [typeorm_1.DataSource])
39
+ ], AuditSubscriber);
40
+ //# sourceMappingURL=audit.subscriber.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.subscriber.js","sourceRoot":"","sources":["../../../src/core/subscribers/audit.subscriber.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAMiB;AACjB,2CAA4C;AAC5C,oFAA+E;AAIxE,IAAM,eAAe,GAArB,MAAM,eAAe;IAC1B,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QACxC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAEO,YAAY,CAAC,MAAW,EAAE,OAAY;IAE9C,CAAC;IAED,YAAY,CAAC,KAAuB;QAClC,MAAM,OAAO,GAAG,+CAAqB,CAAC,iBAAiB,EAAE,CAAC;QAC1D,IAAI,OAAO,IAAI,KAAK,CAAC,MAAM;YAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxE,CAAC;IAED,YAAY,CAAC,KAAuB;QAClC,MAAM,OAAO,GAAG,+CAAqB,CAAC,iBAAiB,EAAE,CAAC;QAC1D,IAAI,OAAO,IAAI,KAAK,CAAC,MAAM;YAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxE,CAAC;CACF,CAAA;AAlBY,0CAAe;0BAAf,eAAe;IAF3B,IAAA,mBAAU,GAAE;IACZ,IAAA,yBAAe,GAAE;qCAEgB,oBAAU;GAD/B,eAAe,CAkB3B"}
@@ -0,0 +1,2 @@
1
+ export declare class CoreModule {
2
+ }
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.CoreModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const passport_1 = require("@nestjs/passport");
12
+ const jwt_1 = require("@nestjs/jwt");
13
+ const core_1 = require("@nestjs/core");
14
+ const jwt_config_1 = require("./config/jwt.config");
15
+ const request_info_service_1 = require("./services/request-info.service");
16
+ const jwt_service_1 = require("./services/jwt.service");
17
+ const session_service_1 = require("./services/session.service");
18
+ const redis_service_1 = require("./services/redis.service");
19
+ const rabbitmq_publisher_service_1 = require("./services/rabbitmq-publisher.service");
20
+ const jwt_strategy_1 = require("./strategies/jwt.strategy");
21
+ const jwt_auth_guard_1 = require("./guards/jwt-auth.guard");
22
+ const internal_auth_guard_1 = require("./guards/internal-auth.guard");
23
+ const request_context_interceptor_1 = require("./interceptors/request-context.interceptor");
24
+ const audit_subscriber_1 = require("./subscribers/audit.subscriber");
25
+ let CoreModule = class CoreModule {
26
+ };
27
+ exports.CoreModule = CoreModule;
28
+ exports.CoreModule = CoreModule = __decorate([
29
+ (0, common_1.Global)(),
30
+ (0, common_1.Module)({
31
+ imports: [
32
+ passport_1.PassportModule,
33
+ jwt_1.JwtModule.registerAsync({
34
+ global: true,
35
+ useFactory: () => ({
36
+ secret: jwt_config_1.jwtConfig.secret,
37
+ signOptions: {
38
+ expiresIn: jwt_config_1.jwtConfig.expiresIn,
39
+ },
40
+ }),
41
+ }),
42
+ ],
43
+ providers: [
44
+ request_info_service_1.RequestInfoService,
45
+ jwt_service_1.CoreJwtService,
46
+ session_service_1.SessionService,
47
+ redis_service_1.RedisService,
48
+ rabbitmq_publisher_service_1.RabbitMQPublisher,
49
+ jwt_strategy_1.JwtStrategy,
50
+ jwt_auth_guard_1.JwtAuthGuard,
51
+ internal_auth_guard_1.InternalAuthGuard,
52
+ request_context_interceptor_1.RequestContextInterceptor,
53
+ {
54
+ provide: core_1.APP_INTERCEPTOR,
55
+ useClass: request_context_interceptor_1.RequestContextInterceptor,
56
+ },
57
+ audit_subscriber_1.AuditSubscriber,
58
+ ],
59
+ exports: [
60
+ request_info_service_1.RequestInfoService,
61
+ jwt_service_1.CoreJwtService,
62
+ session_service_1.SessionService,
63
+ redis_service_1.RedisService,
64
+ rabbitmq_publisher_service_1.RabbitMQPublisher,
65
+ jwt_strategy_1.JwtStrategy,
66
+ jwt_auth_guard_1.JwtAuthGuard,
67
+ internal_auth_guard_1.InternalAuthGuard,
68
+ request_context_interceptor_1.RequestContextInterceptor,
69
+ ],
70
+ })
71
+ ], CoreModule);
72
+ //# sourceMappingURL=core.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core.module.js","sourceRoot":"","sources":["../src/core.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,+CAAkD;AAClD,qCAAwC;AACxC,uCAA+C;AAC/C,oDAAgD;AAGhD,0EAAqE;AACrE,wDAAwD;AACxD,gEAA4D;AAC5D,4DAAwD;AACxD,sFAA0E;AAG1E,4DAAwD;AAGxD,4DAAuD;AACvD,sEAAiE;AAGjE,4FAAuF;AAGvF,qEAAiE;AAqD1D,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAnDtB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,yBAAc;YACd,eAAS,CAAC,aAAa,CAAC;gBACtB,MAAM,EAAE,IAAI;gBACZ,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;oBACjB,MAAM,EAAE,sBAAS,CAAC,MAAM;oBACxB,WAAW,EAAE;wBACX,SAAS,EAAE,sBAAS,CAAC,SAAS;qBAC/B;iBACF,CAAC;aACH,CAAC;SACH;QACD,SAAS,EAAE;YAET,yCAAkB;YAClB,4BAAc;YACd,gCAAc;YACd,4BAAY;YACZ,8CAAiB;YAEjB,0BAAW;YAEX,6BAAY;YACZ,uCAAiB;YAEjB,uDAAyB;YACzB;gBACE,OAAO,EAAE,sBAAe;gBACxB,QAAQ,EAAE,uDAAyB;aACpC;YAED,kCAAe;SAChB;QACD,OAAO,EAAE;YAEP,yCAAkB;YAClB,4BAAc;YACd,gCAAc;YACd,4BAAY;YACZ,8CAAiB;YAEjB,0BAAW;YAEX,6BAAY;YACZ,uCAAiB;YAEjB,uDAAyB;SAC1B;KACF,CAAC;GACW,UAAU,CAAG"}
@@ -0,0 +1 @@
1
+ export declare const CurrentUser: (...dataOrPipes: unknown[]) => ParameterDecorator;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CurrentUser = void 0;
4
+ const common_1 = require("@nestjs/common");
5
+ exports.CurrentUser = (0, common_1.createParamDecorator)((data, ctx) => {
6
+ const request = ctx.switchToHttp().getRequest();
7
+ return request.user;
8
+ });
9
+ //# sourceMappingURL=current-user.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"current-user.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-user.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAwE;AAE3D,QAAA,WAAW,GAAG,IAAA,6BAAoB,EAC7C,CAAC,IAAa,EAAE,GAAqB,EAAE,EAAE;IACvC,MAAM,OAAO,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;IAChD,OAAO,OAAO,CAAC,IAAI,CAAC;AACtB,CAAC,CACF,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const IS_PUBLIC_KEY = "isPublic";
2
+ export declare const Public: () => import("@nestjs/common").CustomDecorator<string>;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Public = exports.IS_PUBLIC_KEY = void 0;
4
+ const common_1 = require("@nestjs/common");
5
+ exports.IS_PUBLIC_KEY = 'isPublic';
6
+ const Public = () => (0, common_1.SetMetadata)(exports.IS_PUBLIC_KEY, true);
7
+ exports.Public = Public;
8
+ //# sourceMappingURL=public.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"public.decorator.js","sourceRoot":"","sources":["../../src/decorators/public.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEhC,QAAA,aAAa,GAAG,UAAU,CAAC;AACjC,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,IAAA,oBAAW,EAAC,qBAAa,EAAE,IAAI,CAAC,CAAC;AAAhD,QAAA,MAAM,UAA0C"}
@@ -0,0 +1,4 @@
1
+ export declare const PERMISSIONS_KEY = "permissions";
2
+ export declare const ANY_PERMISSIONS_KEY = "any_permissions";
3
+ export declare const RequirePermissions: (permissions: string[]) => import("@nestjs/common").CustomDecorator<string>;
4
+ export declare const RequireAnyPermission: (permissions: string[]) => import("@nestjs/common").CustomDecorator<string>;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RequireAnyPermission = exports.RequirePermissions = exports.ANY_PERMISSIONS_KEY = exports.PERMISSIONS_KEY = void 0;
4
+ const common_1 = require("@nestjs/common");
5
+ exports.PERMISSIONS_KEY = "permissions";
6
+ exports.ANY_PERMISSIONS_KEY = "any_permissions";
7
+ const RequirePermissions = (permissions) => (0, common_1.SetMetadata)(exports.PERMISSIONS_KEY, permissions);
8
+ exports.RequirePermissions = RequirePermissions;
9
+ const RequireAnyPermission = (permissions) => (0, common_1.SetMetadata)(exports.ANY_PERMISSIONS_KEY, permissions);
10
+ exports.RequireAnyPermission = RequireAnyPermission;
11
+ //# sourceMappingURL=require-permissions.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-permissions.decorator.js","sourceRoot":"","sources":["../../src/decorators/require-permissions.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEhC,QAAA,eAAe,GAAG,aAAa,CAAC;AAChC,QAAA,mBAAmB,GAAG,iBAAiB,CAAC;AAQ9C,MAAM,kBAAkB,GAAG,CAAC,WAAqB,EAAE,EAAE,CAC1D,IAAA,oBAAW,EAAC,uBAAe,EAAE,WAAW,CAAC,CAAC;AAD/B,QAAA,kBAAkB,sBACa;AAQrC,MAAM,oBAAoB,GAAG,CAAC,WAAqB,EAAE,EAAE,CAC5D,IAAA,oBAAW,EAAC,2BAAmB,EAAE,WAAW,CAAC,CAAC;AADnC,QAAA,oBAAoB,wBACe"}
@@ -0,0 +1,10 @@
1
+ export declare class ApiResponseDto<T = any> {
2
+ success: boolean;
3
+ message: string;
4
+ data?: T;
5
+ timestamp: string;
6
+ statusCode: number;
7
+ constructor(success: boolean, message: string, data?: T, statusCode?: number);
8
+ static success<T>(data?: T, message?: string): ApiResponseDto<T>;
9
+ static error(message?: string, statusCode?: number): ApiResponseDto;
10
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ApiResponseDto = void 0;
4
+ const common_1 = require("@nestjs/common");
5
+ const messages_constants_1 = require("../constants/messages.constants");
6
+ class ApiResponseDto {
7
+ constructor(success, message, data, statusCode = common_1.HttpStatus.OK) {
8
+ this.success = success;
9
+ this.message = message;
10
+ this.data = data;
11
+ this.statusCode = statusCode;
12
+ this.timestamp = new Date().toISOString();
13
+ }
14
+ static success(data, message = messages_constants_1.MESSAGES.API.SUCCESS) {
15
+ return new ApiResponseDto(true, message, data, common_1.HttpStatus.OK);
16
+ }
17
+ static error(message = messages_constants_1.MESSAGES.API.ERROR, statusCode = common_1.HttpStatus.BAD_REQUEST) {
18
+ return new ApiResponseDto(false, message, null, statusCode);
19
+ }
20
+ }
21
+ exports.ApiResponseDto = ApiResponseDto;
22
+ //# sourceMappingURL=api-response.dto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-response.dto.js","sourceRoot":"","sources":["../../src/dtos/api-response.dto.ts"],"names":[],"mappings":";;;AAAA,2CAA4C;AAC5C,wEAA2D;AAE3D,MAAa,cAAc;IAOzB,YACE,OAAgB,EAChB,OAAe,EACf,IAAQ,EACR,aAAqB,mBAAU,CAAC,EAAE;QAElC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED,MAAM,CAAC,OAAO,CACZ,IAAQ,EACR,UAAkB,6BAAQ,CAAC,GAAG,CAAC,OAAO;QAEtC,OAAO,IAAI,cAAc,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,mBAAU,CAAC,EAAE,CAAC,CAAC;IAChE,CAAC;IAED,MAAM,CAAC,KAAK,CACV,UAAkB,6BAAQ,CAAC,GAAG,CAAC,KAAK,EACpC,aAAqB,mBAAU,CAAC,WAAW;QAE3C,OAAO,IAAI,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;IAC9D,CAAC;CACF;AAjCD,wCAiCC"}
@@ -0,0 +1,17 @@
1
+ export declare class PaginationDto {
2
+ page?: number;
3
+ limit?: number;
4
+ search?: string;
5
+ sortBy?: string;
6
+ sortType?: "ASC" | "DESC";
7
+ }
8
+ export declare class PaginationMetaDto {
9
+ page: number;
10
+ limit: number;
11
+ total: number;
12
+ totalPages: number;
13
+ }
14
+ export declare class PaginationResponseDto<T> {
15
+ data: T[];
16
+ meta: PaginationMetaDto;
17
+ }
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.PaginationResponseDto = exports.PaginationMetaDto = exports.PaginationDto = void 0;
13
+ const class_validator_1 = require("class-validator");
14
+ const class_transformer_1 = require("class-transformer");
15
+ const messages_constants_1 = require("../constants/messages.constants");
16
+ class PaginationDto {
17
+ constructor() {
18
+ this.page = 1;
19
+ this.limit = 10;
20
+ this.sortType = "DESC";
21
+ }
22
+ }
23
+ exports.PaginationDto = PaginationDto;
24
+ __decorate([
25
+ (0, class_validator_1.IsOptional)(),
26
+ (0, class_transformer_1.Type)(() => Number),
27
+ (0, class_validator_1.IsNumber)({}, { message: messages_constants_1.MESSAGES.VALIDATION.PAGE_NUMBER }),
28
+ (0, class_validator_1.Min)(1, { message: messages_constants_1.MESSAGES.VALIDATION.PAGE_MIN }),
29
+ __metadata("design:type", Number)
30
+ ], PaginationDto.prototype, "page", void 0);
31
+ __decorate([
32
+ (0, class_validator_1.IsOptional)(),
33
+ (0, class_transformer_1.Type)(() => Number),
34
+ (0, class_validator_1.IsNumber)({}, { message: messages_constants_1.MESSAGES.VALIDATION.LIMIT_NUMBER }),
35
+ (0, class_validator_1.Min)(1, { message: messages_constants_1.MESSAGES.VALIDATION.LIMIT_MIN }),
36
+ (0, class_validator_1.Max)(100, { message: messages_constants_1.MESSAGES.VALIDATION.LIMIT_MAX }),
37
+ __metadata("design:type", Number)
38
+ ], PaginationDto.prototype, "limit", void 0);
39
+ __decorate([
40
+ (0, class_validator_1.IsOptional)(),
41
+ (0, class_transformer_1.Transform)(({ value }) => value?.trim()),
42
+ __metadata("design:type", String)
43
+ ], PaginationDto.prototype, "search", void 0);
44
+ __decorate([
45
+ (0, class_validator_1.IsOptional)(),
46
+ (0, class_validator_1.IsString)({ message: messages_constants_1.MESSAGES.VALIDATION.ORDER_BY_STRING }),
47
+ __metadata("design:type", String)
48
+ ], PaginationDto.prototype, "sortBy", void 0);
49
+ __decorate([
50
+ (0, class_validator_1.IsOptional)(),
51
+ (0, class_validator_1.IsString)({ message: messages_constants_1.MESSAGES.VALIDATION.ORDER_STRING }),
52
+ (0, class_validator_1.IsIn)(["ASC", "DESC"], { message: messages_constants_1.MESSAGES.VALIDATION.ORDER_INVALID }),
53
+ __metadata("design:type", String)
54
+ ], PaginationDto.prototype, "sortType", void 0);
55
+ class PaginationMetaDto {
56
+ }
57
+ exports.PaginationMetaDto = PaginationMetaDto;
58
+ class PaginationResponseDto {
59
+ }
60
+ exports.PaginationResponseDto = PaginationResponseDto;
61
+ //# sourceMappingURL=pagination.dto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pagination.dto.js","sourceRoot":"","sources":["../../src/dtos/pagination.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAOyB;AACzB,yDAAoD;AACpD,wEAA2D;AAE3D,MAAa,aAAa;IAA1B;QAKE,SAAI,GAAY,CAAC,CAAC;QAOlB,UAAK,GAAY,EAAE,CAAC;QAapB,aAAQ,GAAoB,MAAM,CAAC;IACrC,CAAC;CAAA;AA1BD,sCA0BC;AArBC;IAJC,IAAA,4BAAU,GAAE;IACZ,IAAA,wBAAI,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC;IAClB,IAAA,0BAAQ,EAAC,EAAE,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IAC1D,IAAA,qBAAG,EAAC,CAAC,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;;2CAChC;AAOlB;IALC,IAAA,4BAAU,GAAE;IACZ,IAAA,wBAAI,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC;IAClB,IAAA,0BAAQ,EAAC,EAAE,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;IAC3D,IAAA,qBAAG,EAAC,CAAC,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;IAClD,IAAA,qBAAG,EAAC,GAAG,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;;4CACjC;AAIpB;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;;6CACxB;AAIhB;IAFC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,EAAC,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC;;6CAC3C;AAKhB;IAHC,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,EAAC,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;IACvD,IAAA,sBAAI,EAAC,CAAC,KAAK,EAAE,MAAM,CAAC,EAAE,EAAE,OAAO,EAAE,6BAAQ,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;;+CACnC;AAGrC,MAAa,iBAAiB;CAK7B;AALD,8CAKC;AAED,MAAa,qBAAqB;CAGjC;AAHD,sDAGC"}
@@ -0,0 +1,5 @@
1
+ import { ExceptionFilter, ArgumentsHost } from "@nestjs/common";
2
+ export declare class HttpExceptionFilter implements ExceptionFilter {
3
+ private readonly logger;
4
+ catch(exception: unknown, host: ArgumentsHost): void;
5
+ }
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var HttpExceptionFilter_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.HttpExceptionFilter = void 0;
11
+ const common_1 = require("@nestjs/common");
12
+ const api_response_dto_1 = require("../dtos/api-response.dto");
13
+ const messages_constants_1 = require("../constants/messages.constants");
14
+ let HttpExceptionFilter = HttpExceptionFilter_1 = class HttpExceptionFilter {
15
+ constructor() {
16
+ this.logger = new common_1.Logger(HttpExceptionFilter_1.name);
17
+ }
18
+ catch(exception, host) {
19
+ const ctx = host.switchToHttp();
20
+ const response = ctx.getResponse();
21
+ let status = common_1.HttpStatus.INTERNAL_SERVER_ERROR;
22
+ let message = messages_constants_1.MESSAGES.API.INTERNAL_SERVER_ERROR;
23
+ if (exception instanceof common_1.HttpException) {
24
+ status = exception.getStatus();
25
+ const exceptionResponse = exception.getResponse();
26
+ message =
27
+ typeof exceptionResponse === "string"
28
+ ? exceptionResponse
29
+ : exceptionResponse.message || exception.message;
30
+ }
31
+ else if (exception instanceof Error) {
32
+ message = exception.message;
33
+ this.logger.error(`Unexpected error: ${exception.message}`, exception.stack);
34
+ }
35
+ else {
36
+ message = messages_constants_1.MESSAGES.API.UNEXPECTED_ERROR;
37
+ this.logger.error("Unknown exception:", exception);
38
+ }
39
+ const errorResponse = api_response_dto_1.ApiResponseDto.error(message, status);
40
+ response.status(status).json(errorResponse);
41
+ }
42
+ };
43
+ exports.HttpExceptionFilter = HttpExceptionFilter;
44
+ exports.HttpExceptionFilter = HttpExceptionFilter = HttpExceptionFilter_1 = __decorate([
45
+ (0, common_1.Catch)()
46
+ ], HttpExceptionFilter);
47
+ //# sourceMappingURL=http-exception.filter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-exception.filter.js","sourceRoot":"","sources":["../../src/filters/http-exception.filter.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAOwB;AAExB,+DAA0D;AAC1D,wEAA2D;AAGpD,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAAzB;QACY,WAAM,GAAG,IAAI,eAAM,CAAC,qBAAmB,CAAC,IAAI,CAAC,CAAC;IA+BjE,CAAC;IA7BC,KAAK,CAAC,SAAkB,EAAE,IAAmB;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAY,CAAC;QAE7C,IAAI,MAAM,GAAG,mBAAU,CAAC,qBAAqB,CAAC;QAC9C,IAAI,OAAO,GAAW,6BAAQ,CAAC,GAAG,CAAC,qBAAqB,CAAC;QAEzD,IAAI,SAAS,YAAY,sBAAa,EAAE,CAAC;YACvC,MAAM,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC;YAC/B,MAAM,iBAAiB,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;YAClD,OAAO;gBACL,OAAO,iBAAiB,KAAK,QAAQ;oBACnC,CAAC,CAAC,iBAAiB;oBACnB,CAAC,CAAE,iBAAyB,CAAC,OAAO,IAAI,SAAS,CAAC,OAAO,CAAC;QAChE,CAAC;aAAM,IAAI,SAAS,YAAY,KAAK,EAAE,CAAC;YACtC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;YAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,qBAAqB,SAAS,CAAC,OAAO,EAAE,EACxC,SAAS,CAAC,KAAK,CAChB,CAAC;QACJ,CAAC;aAAM,CAAC;YAEN,OAAO,GAAG,6BAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC;YACxC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,EAAE,SAAS,CAAC,CAAC;QACrD,CAAC;QAED,MAAM,aAAa,GAAG,iCAAc,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC5D,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC9C,CAAC;CACF,CAAA;AAhCY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,cAAK,GAAE;GACK,mBAAmB,CAgC/B"}
@@ -0,0 +1,7 @@
1
+ import { CanActivate, ExecutionContext } from "@nestjs/common";
2
+ import { CoreJwtService } from "../services/jwt.service";
3
+ export declare class InternalAuthGuard implements CanActivate {
4
+ private readonly coreJwtService;
5
+ constructor(coreJwtService: CoreJwtService);
6
+ canActivate(context: ExecutionContext): boolean;
7
+ }
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.InternalAuthGuard = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const jwt_service_1 = require("../services/jwt.service");
15
+ const messages_constants_1 = require("../constants/messages.constants");
16
+ let InternalAuthGuard = class InternalAuthGuard {
17
+ constructor(coreJwtService) {
18
+ this.coreJwtService = coreJwtService;
19
+ }
20
+ canActivate(context) {
21
+ const request = context.switchToHttp().getRequest();
22
+ const authHeader = request.headers.authorization;
23
+ if (!authHeader || !authHeader.startsWith("Bearer ")) {
24
+ throw new common_1.UnauthorizedException(messages_constants_1.MESSAGES.INTERNAL_AUTH.MISSING_OR_INVALID_HEADER);
25
+ }
26
+ const token = authHeader.split(" ")[1];
27
+ if (!token) {
28
+ throw new common_1.UnauthorizedException(messages_constants_1.MESSAGES.INTERNAL_AUTH.MISSING_INTERNAL_TOKEN);
29
+ }
30
+ const payload = this.coreJwtService.verifyInternalToken(token);
31
+ if (!payload || !payload.service) {
32
+ throw new common_1.UnauthorizedException(messages_constants_1.MESSAGES.INTERNAL_AUTH.INVALID_OR_EXPIRED_INTERNAL_TOKEN);
33
+ }
34
+ return true;
35
+ }
36
+ };
37
+ exports.InternalAuthGuard = InternalAuthGuard;
38
+ exports.InternalAuthGuard = InternalAuthGuard = __decorate([
39
+ (0, common_1.Injectable)(),
40
+ __metadata("design:paramtypes", [jwt_service_1.CoreJwtService])
41
+ ], InternalAuthGuard);
42
+ //# sourceMappingURL=internal-auth.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"internal-auth.guard.js","sourceRoot":"","sources":["../../src/guards/internal-auth.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AACxB,yDAAyD;AACzD,wEAA2D;AAGpD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,YAA6B,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE/D,WAAW,CAAC,OAAyB;QACnC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;QACpD,MAAM,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC;QAEjD,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YACrD,MAAM,IAAI,8BAAqB,CAC7B,6BAAQ,CAAC,aAAa,CAAC,yBAAyB,CACjD,CAAC;QACJ,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEvC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,8BAAqB,CAC7B,6BAAQ,CAAC,aAAa,CAAC,sBAAsB,CAC9C,CAAC;QACJ,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAE/D,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACjC,MAAM,IAAI,8BAAqB,CAC7B,6BAAQ,CAAC,aAAa,CAAC,iCAAiC,CACzD,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA/BY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAEkC,4BAAc;GADhD,iBAAiB,CA+B7B"}
@@ -0,0 +1,12 @@
1
+ import { ExecutionContext } from "@nestjs/common";
2
+ import { Reflector } from "@nestjs/core";
3
+ import { CoreJwtService } from "../services/jwt.service";
4
+ declare const JwtAuthGuard_base: import("@nestjs/passport").Type<import("@nestjs/passport").IAuthGuard>;
5
+ export declare class JwtAuthGuard extends JwtAuthGuard_base {
6
+ private reflector;
7
+ private coreJwtService;
8
+ constructor(reflector: Reflector, coreJwtService: CoreJwtService);
9
+ canActivate(context: ExecutionContext): Promise<boolean>;
10
+ handleRequest(err: any, user: any, info: any): any;
11
+ }
12
+ export {};