mfance-shark-v1 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 +115 -0
- package/dist/common/constants/index.d.ts +57 -0
- package/dist/common/constants/index.js +61 -0
- package/dist/common/constants/index.js.map +1 -0
- package/dist/common/decorators/api-response.decorator.d.ts +8 -0
- package/dist/common/decorators/api-response.decorator.js +23 -0
- package/dist/common/decorators/api-response.decorator.js.map +1 -0
- package/dist/common/decorators/current-user.decorator.d.ts +1 -0
- package/dist/common/decorators/current-user.decorator.js +9 -0
- package/dist/common/decorators/current-user.decorator.js.map +1 -0
- package/dist/common/decorators/index.d.ts +4 -0
- package/dist/common/decorators/index.js +21 -0
- package/dist/common/decorators/index.js.map +1 -0
- package/dist/common/decorators/public.decorator.d.ts +2 -0
- package/dist/common/decorators/public.decorator.js +8 -0
- package/dist/common/decorators/public.decorator.js.map +1 -0
- package/dist/common/decorators/roles.decorator.d.ts +2 -0
- package/dist/common/decorators/roles.decorator.js +8 -0
- package/dist/common/decorators/roles.decorator.js.map +1 -0
- package/dist/common/filters/http-exception.filter.d.ts +4 -0
- package/dist/common/filters/http-exception.filter.js +31 -0
- package/dist/common/filters/http-exception.filter.js.map +1 -0
- package/dist/common/filters/index.d.ts +2 -0
- package/dist/common/filters/index.js +19 -0
- package/dist/common/filters/index.js.map +1 -0
- package/dist/common/filters/validation-exception.filter.d.ts +4 -0
- package/dist/common/filters/validation-exception.filter.js +31 -0
- package/dist/common/filters/validation-exception.filter.js.map +1 -0
- package/dist/common/guards/index.d.ts +2 -0
- package/dist/common/guards/index.js +19 -0
- package/dist/common/guards/index.js.map +1 -0
- package/dist/common/guards/jwt-auth.guard.d.ts +10 -0
- package/dist/common/guards/jwt-auth.guard.js +44 -0
- package/dist/common/guards/jwt-auth.guard.js.map +1 -0
- package/dist/common/guards/roles.guard.d.ts +7 -0
- package/dist/common/guards/roles.guard.js +37 -0
- package/dist/common/guards/roles.guard.js.map +1 -0
- package/dist/common/interceptors/index.d.ts +2 -0
- package/dist/common/interceptors/index.js +19 -0
- package/dist/common/interceptors/index.js.map +1 -0
- package/dist/common/interceptors/logging.interceptor.d.ts +5 -0
- package/dist/common/interceptors/logging.interceptor.js +29 -0
- package/dist/common/interceptors/logging.interceptor.js.map +1 -0
- package/dist/common/interceptors/transform.interceptor.d.ts +11 -0
- package/dist/common/interceptors/transform.interceptor.js +26 -0
- package/dist/common/interceptors/transform.interceptor.js.map +1 -0
- package/dist/common/utils/crypto.util.d.ts +6 -0
- package/dist/common/utils/crypto.util.js +27 -0
- package/dist/common/utils/crypto.util.js.map +1 -0
- package/dist/common/utils/date.util.d.ts +12 -0
- package/dist/common/utils/date.util.js +58 -0
- package/dist/common/utils/date.util.js.map +1 -0
- package/dist/common/utils/index.d.ts +4 -0
- package/dist/common/utils/index.js +21 -0
- package/dist/common/utils/index.js.map +1 -0
- package/dist/common/utils/string.util.d.ts +16 -0
- package/dist/common/utils/string.util.js +73 -0
- package/dist/common/utils/string.util.js.map +1 -0
- package/dist/common/utils/validation.util.d.ts +12 -0
- package/dist/common/utils/validation.util.js +41 -0
- package/dist/common/utils/validation.util.js.map +1 -0
- package/dist/dto/auth/auth-response.dto.d.ts +12 -0
- package/dist/dto/auth/auth-response.dto.js +51 -0
- package/dist/dto/auth/auth-response.dto.js.map +1 -0
- package/dist/dto/auth/index.d.ts +4 -0
- package/dist/dto/auth/index.js +21 -0
- package/dist/dto/auth/index.js.map +1 -0
- package/dist/dto/auth/login.dto.d.ts +4 -0
- package/dist/dto/auth/login.dto.js +38 -0
- package/dist/dto/auth/login.dto.js.map +1 -0
- package/dist/dto/auth/refresh-token.dto.d.ts +3 -0
- package/dist/dto/auth/refresh-token.dto.js +27 -0
- package/dist/dto/auth/refresh-token.dto.js.map +1 -0
- package/dist/dto/auth/register.dto.d.ts +7 -0
- package/dist/dto/auth/register.dto.js +66 -0
- package/dist/dto/auth/register.dto.js.map +1 -0
- package/dist/dto/balance/balance-response.dto.d.ts +8 -0
- package/dist/dto/balance/balance-response.dto.js +59 -0
- package/dist/dto/balance/balance-response.dto.js.map +1 -0
- package/dist/dto/balance/balance.dto.d.ts +8 -0
- package/dist/dto/balance/balance.dto.js +67 -0
- package/dist/dto/balance/balance.dto.js.map +1 -0
- package/dist/dto/balance/index.d.ts +2 -0
- package/dist/dto/balance/index.js +19 -0
- package/dist/dto/balance/index.js.map +1 -0
- package/dist/dto/transaction/create-transaction.dto.d.ts +9 -0
- package/dist/dto/transaction/create-transaction.dto.js +73 -0
- package/dist/dto/transaction/create-transaction.dto.js.map +1 -0
- package/dist/dto/transaction/index.d.ts +4 -0
- package/dist/dto/transaction/index.js +21 -0
- package/dist/dto/transaction/index.js.map +1 -0
- package/dist/dto/transaction/transaction-response.dto.d.ts +13 -0
- package/dist/dto/transaction/transaction-response.dto.js +91 -0
- package/dist/dto/transaction/transaction-response.dto.js.map +1 -0
- package/dist/dto/transaction/transaction.dto.d.ts +23 -0
- package/dist/dto/transaction/transaction.dto.js +108 -0
- package/dist/dto/transaction/transaction.dto.js.map +1 -0
- package/dist/dto/transaction/update-transaction.dto.d.ts +6 -0
- package/dist/dto/transaction/update-transaction.dto.js +50 -0
- package/dist/dto/transaction/update-transaction.dto.js.map +1 -0
- package/dist/dto/user/create-user.dto.d.ts +7 -0
- package/dist/dto/user/create-user.dto.js +66 -0
- package/dist/dto/user/create-user.dto.js.map +1 -0
- package/dist/dto/user/index.d.ts +4 -0
- package/dist/dto/user/index.js +21 -0
- package/dist/dto/user/index.js.map +1 -0
- package/dist/dto/user/update-user.dto.d.ts +6 -0
- package/dist/dto/user/update-user.dto.js +58 -0
- package/dist/dto/user/update-user.dto.js.map +1 -0
- package/dist/dto/user/user-response.dto.d.ts +9 -0
- package/dist/dto/user/user-response.dto.js +67 -0
- package/dist/dto/user/user-response.dto.js.map +1 -0
- package/dist/dto/user/user.dto.d.ts +9 -0
- package/dist/dto/user/user.dto.js +77 -0
- package/dist/dto/user/user.dto.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/api-response.interface.d.ts +29 -0
- package/dist/interfaces/api-response.interface.js +3 -0
- package/dist/interfaces/api-response.interface.js.map +1 -0
- package/dist/interfaces/balance.interface.d.ts +25 -0
- package/dist/interfaces/balance.interface.js +3 -0
- package/dist/interfaces/balance.interface.js.map +1 -0
- package/dist/interfaces/index.d.ts +3 -0
- package/dist/interfaces/index.js +20 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/interfaces/pagination.interface.d.ts +20 -0
- package/dist/interfaces/pagination.interface.js +3 -0
- package/dist/interfaces/pagination.interface.js.map +1 -0
- package/dist/interfaces/transaction.interface.d.ts +38 -0
- package/dist/interfaces/transaction.interface.js +3 -0
- package/dist/interfaces/transaction.interface.js.map +1 -0
- package/dist/interfaces/user.interface.d.ts +36 -0
- package/dist/interfaces/user.interface.js +3 -0
- package/dist/interfaces/user.interface.js.map +1 -0
- package/dist/services/auth/auth.service.d.ts +20 -0
- package/dist/services/auth/auth.service.js +65 -0
- package/dist/services/auth/auth.service.js.map +1 -0
- package/dist/services/auth/index.d.ts +1 -0
- package/dist/services/auth/index.js +18 -0
- package/dist/services/auth/index.js.map +1 -0
- package/dist/services/logger/index.d.ts +1 -0
- package/dist/services/logger/index.js +18 -0
- package/dist/services/logger/index.js.map +1 -0
- package/dist/services/logger/logger.service.d.ts +11 -0
- package/dist/services/logger/logger.service.js +61 -0
- package/dist/services/logger/logger.service.js.map +1 -0
- package/dist/services/validation/index.d.ts +1 -0
- package/dist/services/validation/index.js +18 -0
- package/dist/services/validation/index.js.map +1 -0
- package/dist/services/validation/validation.service.d.ts +13 -0
- package/dist/services/validation/validation.service.js +55 -0
- package/dist/services/validation/validation.service.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +103 -0
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export interface IUser {
|
|
2
|
+
id: string;
|
|
3
|
+
firstName: string;
|
|
4
|
+
lastName: string;
|
|
5
|
+
email: string;
|
|
6
|
+
phone?: string;
|
|
7
|
+
password?: string;
|
|
8
|
+
isActive: boolean;
|
|
9
|
+
roles: string[];
|
|
10
|
+
createdAt: Date;
|
|
11
|
+
updatedAt: Date;
|
|
12
|
+
}
|
|
13
|
+
export interface IUserCreate {
|
|
14
|
+
firstName: string;
|
|
15
|
+
lastName: string;
|
|
16
|
+
email: string;
|
|
17
|
+
password: string;
|
|
18
|
+
phone?: string;
|
|
19
|
+
}
|
|
20
|
+
export interface IUserUpdate {
|
|
21
|
+
firstName?: string;
|
|
22
|
+
lastName?: string;
|
|
23
|
+
email?: string;
|
|
24
|
+
phone?: string;
|
|
25
|
+
}
|
|
26
|
+
export interface IUserResponse {
|
|
27
|
+
id: string;
|
|
28
|
+
firstName: string;
|
|
29
|
+
lastName: string;
|
|
30
|
+
email: string;
|
|
31
|
+
phone?: string;
|
|
32
|
+
isActive: boolean;
|
|
33
|
+
roles: string[];
|
|
34
|
+
createdAt: Date;
|
|
35
|
+
updatedAt: Date;
|
|
36
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.interface.js","sourceRoot":"","sources":["../../src/interfaces/user.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { JwtService } from '@nestjs/jwt';
|
|
2
|
+
export declare class AuthService {
|
|
3
|
+
private readonly jwtService;
|
|
4
|
+
constructor(jwtService: JwtService);
|
|
5
|
+
hashPassword(password: string): Promise<string>;
|
|
6
|
+
comparePassword(password: string, hashedPassword: string): Promise<boolean>;
|
|
7
|
+
generateTokens(payload: any): Promise<{
|
|
8
|
+
accessToken: string;
|
|
9
|
+
refreshToken: string;
|
|
10
|
+
tokenType: string;
|
|
11
|
+
expiresIn: number;
|
|
12
|
+
}>;
|
|
13
|
+
verifyToken(token: string): Promise<any>;
|
|
14
|
+
refreshToken(refreshToken: string): Promise<{
|
|
15
|
+
accessToken: string;
|
|
16
|
+
refreshToken: string;
|
|
17
|
+
tokenType: string;
|
|
18
|
+
expiresIn: number;
|
|
19
|
+
}>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
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.AuthService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const jwt_1 = require("@nestjs/jwt");
|
|
15
|
+
const crypto_util_1 = require("../../common/utils/crypto.util");
|
|
16
|
+
let AuthService = class AuthService {
|
|
17
|
+
constructor(jwtService) {
|
|
18
|
+
this.jwtService = jwtService;
|
|
19
|
+
}
|
|
20
|
+
async hashPassword(password) {
|
|
21
|
+
return crypto_util_1.CryptoUtil.hashPassword(password);
|
|
22
|
+
}
|
|
23
|
+
async comparePassword(password, hashedPassword) {
|
|
24
|
+
return crypto_util_1.CryptoUtil.comparePassword(password, hashedPassword);
|
|
25
|
+
}
|
|
26
|
+
async generateTokens(payload) {
|
|
27
|
+
const [accessToken, refreshToken] = await Promise.all([
|
|
28
|
+
this.jwtService.signAsync(payload, {
|
|
29
|
+
expiresIn: '15m',
|
|
30
|
+
}),
|
|
31
|
+
this.jwtService.signAsync(payload, {
|
|
32
|
+
expiresIn: '7d',
|
|
33
|
+
}),
|
|
34
|
+
]);
|
|
35
|
+
return {
|
|
36
|
+
accessToken,
|
|
37
|
+
refreshToken,
|
|
38
|
+
tokenType: 'Bearer',
|
|
39
|
+
expiresIn: 900,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
async verifyToken(token) {
|
|
43
|
+
try {
|
|
44
|
+
return await this.jwtService.verifyAsync(token);
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
throw new Error('Invalid token');
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async refreshToken(refreshToken) {
|
|
51
|
+
try {
|
|
52
|
+
const payload = await this.jwtService.verifyAsync(refreshToken);
|
|
53
|
+
return this.generateTokens(payload);
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
throw new Error('Invalid refresh token');
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
exports.AuthService = AuthService;
|
|
61
|
+
exports.AuthService = AuthService = __decorate([
|
|
62
|
+
(0, common_1.Injectable)(),
|
|
63
|
+
__metadata("design:paramtypes", [jwt_1.JwtService])
|
|
64
|
+
], AuthService);
|
|
65
|
+
//# sourceMappingURL=auth.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../src/services/auth/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,qCAAyC;AACzC,gEAA4D;AAGrD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACtB,YAA6B,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;IAAG,CAAC;IAEvD,KAAK,CAAC,YAAY,CAAC,QAAgB;QACjC,OAAO,wBAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,QAAgB,EAAE,cAAsB;QAC5D,OAAO,wBAAU,CAAC,eAAe,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;IAC9D,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,OAAY;QAC/B,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACpD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,EAAE;gBACjC,SAAS,EAAE,KAAK;aACjB,CAAC;YACF,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,EAAE;gBACjC,SAAS,EAAE,IAAI;aAChB,CAAC;SACH,CAAC,CAAC;QAEH,OAAO;YACL,WAAW;YACX,YAAY;YACZ,SAAS,EAAE,QAAQ;YACnB,SAAS,EAAE,GAAG;SACf,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,IAAI,CAAC;YACH,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAClD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,YAAoB;QACrC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;YAChE,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;CACF,CAAA;AA7CY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAE8B,gBAAU;GADxC,WAAW,CA6CvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './auth.service';
|
|
@@ -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.service"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/auth/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './logger.service';
|
|
@@ -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("./logger.service"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/logger/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { LoggerService as NestLoggerService } from '@nestjs/common';
|
|
2
|
+
export declare class LoggerService implements NestLoggerService {
|
|
3
|
+
private logger;
|
|
4
|
+
constructor();
|
|
5
|
+
private initializeLogger;
|
|
6
|
+
log(message: string, context?: string): void;
|
|
7
|
+
error(message: string, trace?: string, context?: string): void;
|
|
8
|
+
warn(message: string, context?: string): void;
|
|
9
|
+
debug(message: string, context?: string): void;
|
|
10
|
+
verbose(message: string, context?: string): void;
|
|
11
|
+
}
|
|
@@ -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.LoggerService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const winston = require("winston");
|
|
15
|
+
const DailyRotateFile = require("winston-daily-rotate-file");
|
|
16
|
+
let LoggerService = class LoggerService {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.initializeLogger();
|
|
19
|
+
}
|
|
20
|
+
initializeLogger() {
|
|
21
|
+
const logFormat = winston.format.combine(winston.format.timestamp(), winston.format.errors({ stack: true }), winston.format.json());
|
|
22
|
+
const fileTransport = new DailyRotateFile({
|
|
23
|
+
filename: 'logs/application-%DATE%.log',
|
|
24
|
+
datePattern: 'YYYY-MM-DD',
|
|
25
|
+
zippedArchive: true,
|
|
26
|
+
maxSize: '20m',
|
|
27
|
+
maxFiles: '14d',
|
|
28
|
+
});
|
|
29
|
+
this.logger = winston.createLogger({
|
|
30
|
+
level: process.env.LOG_LEVEL || 'info',
|
|
31
|
+
format: logFormat,
|
|
32
|
+
transports: [
|
|
33
|
+
fileTransport,
|
|
34
|
+
new winston.transports.Console({
|
|
35
|
+
format: winston.format.combine(winston.format.colorize(), winston.format.simple()),
|
|
36
|
+
}),
|
|
37
|
+
],
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
log(message, context) {
|
|
41
|
+
this.logger.info(message, { context });
|
|
42
|
+
}
|
|
43
|
+
error(message, trace, context) {
|
|
44
|
+
this.logger.error(message, { trace, context });
|
|
45
|
+
}
|
|
46
|
+
warn(message, context) {
|
|
47
|
+
this.logger.warn(message, { context });
|
|
48
|
+
}
|
|
49
|
+
debug(message, context) {
|
|
50
|
+
this.logger.debug(message, { context });
|
|
51
|
+
}
|
|
52
|
+
verbose(message, context) {
|
|
53
|
+
this.logger.verbose(message, { context });
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
exports.LoggerService = LoggerService;
|
|
57
|
+
exports.LoggerService = LoggerService = __decorate([
|
|
58
|
+
(0, common_1.Injectable)(),
|
|
59
|
+
__metadata("design:paramtypes", [])
|
|
60
|
+
], LoggerService);
|
|
61
|
+
//# sourceMappingURL=logger.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.service.js","sourceRoot":"","sources":["../../../src/services/logger/logger.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAgF;AAChF,mCAAmC;AACnC,6DAA6D;AAGtD,IAAM,aAAa,GAAnB,MAAM,aAAa;IAGxB;QACE,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEO,gBAAgB;QACtB,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,OAAO,CACtC,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,EAC1B,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EACtC,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CACtB,CAAC;QAEF,MAAM,aAAa,GAAG,IAAI,eAAe,CAAC;YACxC,QAAQ,EAAE,6BAA6B;YACvC,WAAW,EAAE,YAAY;YACzB,aAAa,EAAE,IAAI;YACnB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;YACjC,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,MAAM;YACtC,MAAM,EAAE,SAAS;YACjB,UAAU,EAAE;gBACV,aAAa;gBACb,IAAI,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC;oBAC7B,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,CAC5B,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EACzB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CACxB;iBACF,CAAC;aACH;SACF,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,OAAe,EAAE,OAAgB;QACnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,KAAc,EAAE,OAAgB;QACrD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,OAAgB;QACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,OAAgB;QACrC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,OAAO,CAAC,OAAe,EAAE,OAAgB;QACvC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAC5C,CAAC;CACF,CAAA;AAxDY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;;GACA,aAAa,CAwDzB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './validation.service';
|
|
@@ -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("./validation.service"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/validation/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare class ValidationService {
|
|
2
|
+
validateEmail(email: string): boolean;
|
|
3
|
+
validatePassword(password: string): boolean;
|
|
4
|
+
validatePhoneNumber(phone: string): boolean;
|
|
5
|
+
validateUUID(uuid: string): boolean;
|
|
6
|
+
validateRequired(value: any): boolean;
|
|
7
|
+
validateNumber(value: any): boolean;
|
|
8
|
+
validateString(value: any): boolean;
|
|
9
|
+
validateBoolean(value: any): boolean;
|
|
10
|
+
validateArray(value: any): boolean;
|
|
11
|
+
validateObject(value: any): boolean;
|
|
12
|
+
validatePaginationOptions(page: number, limit: number): boolean;
|
|
13
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
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.ValidationService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const validation_util_1 = require("../../common/utils/validation.util");
|
|
12
|
+
let ValidationService = class ValidationService {
|
|
13
|
+
validateEmail(email) {
|
|
14
|
+
return validation_util_1.ValidationUtil.isValidEmail(email);
|
|
15
|
+
}
|
|
16
|
+
validatePassword(password) {
|
|
17
|
+
return validation_util_1.ValidationUtil.isValidPassword(password);
|
|
18
|
+
}
|
|
19
|
+
validatePhoneNumber(phone) {
|
|
20
|
+
return validation_util_1.ValidationUtil.isValidPhoneNumber(phone);
|
|
21
|
+
}
|
|
22
|
+
validateUUID(uuid) {
|
|
23
|
+
return validation_util_1.ValidationUtil.isValidUUID(uuid);
|
|
24
|
+
}
|
|
25
|
+
validateRequired(value) {
|
|
26
|
+
return validation_util_1.ValidationUtil.isNotEmpty(value);
|
|
27
|
+
}
|
|
28
|
+
validateNumber(value) {
|
|
29
|
+
return validation_util_1.ValidationUtil.isNumber(value);
|
|
30
|
+
}
|
|
31
|
+
validateString(value) {
|
|
32
|
+
return validation_util_1.ValidationUtil.isString(value);
|
|
33
|
+
}
|
|
34
|
+
validateBoolean(value) {
|
|
35
|
+
return validation_util_1.ValidationUtil.isBoolean(value);
|
|
36
|
+
}
|
|
37
|
+
validateArray(value) {
|
|
38
|
+
return validation_util_1.ValidationUtil.isArray(value);
|
|
39
|
+
}
|
|
40
|
+
validateObject(value) {
|
|
41
|
+
return validation_util_1.ValidationUtil.isObject(value);
|
|
42
|
+
}
|
|
43
|
+
validatePaginationOptions(page, limit) {
|
|
44
|
+
return (validation_util_1.ValidationUtil.isNumber(page) &&
|
|
45
|
+
validation_util_1.ValidationUtil.isNumber(limit) &&
|
|
46
|
+
page > 0 &&
|
|
47
|
+
limit > 0 &&
|
|
48
|
+
limit <= 100);
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
exports.ValidationService = ValidationService;
|
|
52
|
+
exports.ValidationService = ValidationService = __decorate([
|
|
53
|
+
(0, common_1.Injectable)()
|
|
54
|
+
], ValidationService);
|
|
55
|
+
//# sourceMappingURL=validation.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.service.js","sourceRoot":"","sources":["../../../src/services/validation/validation.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,wEAAoE;AAG7D,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,aAAa,CAAC,KAAa;QACzB,OAAO,gCAAc,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED,gBAAgB,CAAC,QAAgB;QAC/B,OAAO,gCAAc,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IAClD,CAAC;IAED,mBAAmB,CAAC,KAAa;QAC/B,OAAO,gCAAc,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,OAAO,gCAAc,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,OAAO,gCAAc,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,OAAO,gCAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,OAAO,gCAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,OAAO,gCAAc,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,OAAO,gCAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,OAAO,gCAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,yBAAyB,CAAC,IAAY,EAAE,KAAa;QACnD,OAAO,CACL,gCAAc,CAAC,QAAQ,CAAC,IAAI,CAAC;YAC7B,gCAAc,CAAC,QAAQ,CAAC,KAAK,CAAC;YAC9B,IAAI,GAAG,CAAC;YACR,KAAK,GAAG,CAAC;YACT,KAAK,IAAI,GAAG,CACb,CAAC;IACJ,CAAC;CACF,CAAA;AAlDY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;GACA,iBAAiB,CAkD7B"}
|