@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.
- package/README.md +270 -0
- package/dist/config/cookie.config.d.ts +3 -0
- package/dist/config/cookie.config.js +7 -0
- package/dist/config/cookie.config.js.map +1 -0
- package/dist/config/cors.config.d.ts +6 -0
- package/dist/config/cors.config.js +15 -0
- package/dist/config/cors.config.js.map +1 -0
- package/dist/config/database.config.d.ts +13 -0
- package/dist/config/database.config.js +17 -0
- package/dist/config/database.config.js.map +1 -0
- package/dist/config/google-oauth.config.d.ts +6 -0
- package/dist/config/google-oauth.config.js +10 -0
- package/dist/config/google-oauth.config.js.map +1 -0
- package/dist/config/internal.config.d.ts +8 -0
- package/dist/config/internal.config.js +15 -0
- package/dist/config/internal.config.js.map +1 -0
- package/dist/config/jwt.config.d.ts +5 -0
- package/dist/config/jwt.config.js +9 -0
- package/dist/config/jwt.config.js.map +1 -0
- package/dist/config/rabbitmq.config.d.ts +19 -0
- package/dist/config/rabbitmq.config.js +25 -0
- package/dist/config/rabbitmq.config.js.map +1 -0
- package/dist/config/redis.config.d.ts +9 -0
- package/dist/config/redis.config.js +13 -0
- package/dist/config/redis.config.js.map +1 -0
- package/dist/constants/http-status.constants.d.ts +106 -0
- package/dist/constants/http-status.constants.js +110 -0
- package/dist/constants/http-status.constants.js.map +1 -0
- package/dist/constants/messages.constants.d.ts +112 -0
- package/dist/constants/messages.constants.js +116 -0
- package/dist/constants/messages.constants.js.map +1 -0
- package/dist/core/core.module.d.ts +2 -0
- package/dist/core/core.module.js +72 -0
- package/dist/core/core.module.js.map +1 -0
- package/dist/core/decorators/current-user.decorator.d.ts +1 -0
- package/dist/core/decorators/current-user.decorator.js +9 -0
- package/dist/core/decorators/current-user.decorator.js.map +1 -0
- package/dist/core/decorators/public.decorator.d.ts +2 -0
- package/dist/core/decorators/public.decorator.js +8 -0
- package/dist/core/decorators/public.decorator.js.map +1 -0
- package/dist/core/decorators/require-permissions.decorator.d.ts +4 -0
- package/dist/core/decorators/require-permissions.decorator.js +11 -0
- package/dist/core/decorators/require-permissions.decorator.js.map +1 -0
- package/dist/core/dtos/api-response.dto.d.ts +10 -0
- package/dist/core/dtos/api-response.dto.js +22 -0
- package/dist/core/dtos/api-response.dto.js.map +1 -0
- package/dist/core/dtos/pagination.dto.d.ts +17 -0
- package/dist/core/dtos/pagination.dto.js +61 -0
- package/dist/core/dtos/pagination.dto.js.map +1 -0
- package/dist/core/filters/http-exception.filter.d.ts +5 -0
- package/dist/core/filters/http-exception.filter.js +47 -0
- package/dist/core/filters/http-exception.filter.js.map +1 -0
- package/dist/core/guards/internal-auth.guard.d.ts +7 -0
- package/dist/core/guards/internal-auth.guard.js +42 -0
- package/dist/core/guards/internal-auth.guard.js.map +1 -0
- package/dist/core/guards/jwt-auth.guard.d.ts +12 -0
- package/dist/core/guards/jwt-auth.guard.js +56 -0
- package/dist/core/guards/jwt-auth.guard.js.map +1 -0
- package/dist/core/guards/permission.guard.d.ts +9 -0
- package/dist/core/guards/permission.guard.js +71 -0
- package/dist/core/guards/permission.guard.js.map +1 -0
- package/dist/core/interceptors/request-context.interceptor.d.ts +8 -0
- package/dist/core/interceptors/request-context.interceptor.js +39 -0
- package/dist/core/interceptors/request-context.interceptor.js.map +1 -0
- package/dist/core/services/cache.service.d.ts +13 -0
- package/dist/core/services/cache.service.js +51 -0
- package/dist/core/services/cache.service.js.map +1 -0
- package/dist/core/services/cookie.service.d.ts +13 -0
- package/dist/core/services/cookie.service.js +50 -0
- package/dist/core/services/cookie.service.js.map +1 -0
- package/dist/core/services/jwt.service.d.ts +37 -0
- package/dist/core/services/jwt.service.js +187 -0
- package/dist/core/services/jwt.service.js.map +1 -0
- package/dist/core/services/permission.service.d.ts +23 -0
- package/dist/core/services/permission.service.js +83 -0
- package/dist/core/services/permission.service.js.map +1 -0
- package/dist/core/services/rabbitmq-publisher.service.d.ts +9 -0
- package/dist/core/services/rabbitmq-publisher.service.js +57 -0
- package/dist/core/services/rabbitmq-publisher.service.js.map +1 -0
- package/dist/core/services/redis.service.d.ts +18 -0
- package/dist/core/services/redis.service.js +66 -0
- package/dist/core/services/redis.service.js.map +1 -0
- package/dist/core/services/request-context.service.d.ts +18 -0
- package/dist/core/services/request-context.service.js +40 -0
- package/dist/core/services/request-context.service.js.map +1 -0
- package/dist/core/services/request-info.service.d.ts +8 -0
- package/dist/core/services/request-info.service.js +32 -0
- package/dist/core/services/request-info.service.js.map +1 -0
- package/dist/core/services/session.service.d.ts +21 -0
- package/dist/core/services/session.service.js +70 -0
- package/dist/core/services/session.service.js.map +1 -0
- package/dist/core/strategies/jwt.strategy.d.ts +7 -0
- package/dist/core/strategies/jwt.strategy.js +38 -0
- package/dist/core/strategies/jwt.strategy.js.map +1 -0
- package/dist/core/subscribers/audit.subscriber.d.ts +8 -0
- package/dist/core/subscribers/audit.subscriber.js +40 -0
- package/dist/core/subscribers/audit.subscriber.js.map +1 -0
- package/dist/core.module.d.ts +2 -0
- package/dist/core.module.js +72 -0
- package/dist/core.module.js.map +1 -0
- package/dist/decorators/current-user.decorator.d.ts +1 -0
- package/dist/decorators/current-user.decorator.js +9 -0
- package/dist/decorators/current-user.decorator.js.map +1 -0
- package/dist/decorators/public.decorator.d.ts +2 -0
- package/dist/decorators/public.decorator.js +8 -0
- package/dist/decorators/public.decorator.js.map +1 -0
- package/dist/decorators/require-permissions.decorator.d.ts +4 -0
- package/dist/decorators/require-permissions.decorator.js +11 -0
- package/dist/decorators/require-permissions.decorator.js.map +1 -0
- package/dist/dtos/api-response.dto.d.ts +10 -0
- package/dist/dtos/api-response.dto.js +22 -0
- package/dist/dtos/api-response.dto.js.map +1 -0
- package/dist/dtos/pagination.dto.d.ts +17 -0
- package/dist/dtos/pagination.dto.js +61 -0
- package/dist/dtos/pagination.dto.js.map +1 -0
- package/dist/filters/http-exception.filter.d.ts +5 -0
- package/dist/filters/http-exception.filter.js +47 -0
- package/dist/filters/http-exception.filter.js.map +1 -0
- package/dist/guards/internal-auth.guard.d.ts +7 -0
- package/dist/guards/internal-auth.guard.js +42 -0
- package/dist/guards/internal-auth.guard.js.map +1 -0
- package/dist/guards/jwt-auth.guard.d.ts +12 -0
- package/dist/guards/jwt-auth.guard.js +56 -0
- package/dist/guards/jwt-auth.guard.js.map +1 -0
- package/dist/guards/permission.guard.d.ts +9 -0
- package/dist/guards/permission.guard.js +71 -0
- package/dist/guards/permission.guard.js.map +1 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.js +80 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/request-context.interceptor.d.ts +8 -0
- package/dist/interceptors/request-context.interceptor.js +39 -0
- package/dist/interceptors/request-context.interceptor.js.map +1 -0
- package/dist/libs/axios/axios-client.d.ts +8 -0
- package/dist/libs/axios/axios-client.js +61 -0
- package/dist/libs/axios/axios-client.js.map +1 -0
- package/dist/libs/axios/index.d.ts +1 -0
- package/dist/libs/axios/index.js +8 -0
- package/dist/libs/axios/index.js.map +1 -0
- package/dist/services/cookie.service.d.ts +13 -0
- package/dist/services/cookie.service.js +50 -0
- package/dist/services/cookie.service.js.map +1 -0
- package/dist/services/jwt.service.d.ts +37 -0
- package/dist/services/jwt.service.js +187 -0
- package/dist/services/jwt.service.js.map +1 -0
- package/dist/services/rabbitmq-publisher.service.d.ts +9 -0
- package/dist/services/rabbitmq-publisher.service.js +57 -0
- package/dist/services/rabbitmq-publisher.service.js.map +1 -0
- package/dist/services/redis.service.d.ts +18 -0
- package/dist/services/redis.service.js +66 -0
- package/dist/services/redis.service.js.map +1 -0
- package/dist/services/request-context.service.d.ts +18 -0
- package/dist/services/request-context.service.js +40 -0
- package/dist/services/request-context.service.js.map +1 -0
- package/dist/services/request-info.service.d.ts +8 -0
- package/dist/services/request-info.service.js +32 -0
- package/dist/services/request-info.service.js.map +1 -0
- package/dist/services/session.service.d.ts +21 -0
- package/dist/services/session.service.js +70 -0
- package/dist/services/session.service.js.map +1 -0
- package/dist/strategies/jwt.strategy.d.ts +7 -0
- package/dist/strategies/jwt.strategy.js +38 -0
- package/dist/strategies/jwt.strategy.js.map +1 -0
- package/dist/subscribers/audit.subscriber.d.ts +8 -0
- package/dist/subscribers/audit.subscriber.js +40 -0
- package/dist/subscribers/audit.subscriber.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/utils/date.utils.d.ts +4 -0
- package/dist/utils/date.utils.js +52 -0
- package/dist/utils/date.utils.js.map +1 -0
- 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,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,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,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 {};
|