cqrs-boilerplate-code 1.0.0 → 1.0.2
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/dist/common-infra/common-infra.module.d.ts +4 -0
- package/dist/common-infra/common-infra.module.js +30 -0
- package/dist/common-infra/common-infra.module.js.map +1 -0
- package/dist/common-infra/database/database.module.d.ts +4 -0
- package/dist/common-infra/database/database.module.js +34 -0
- package/dist/common-infra/database/database.module.js.map +1 -0
- package/dist/common-infra/database/typeorm.config.d.ts +3 -0
- package/dist/common-infra/database/typeorm.config.js +18 -0
- package/dist/common-infra/database/typeorm.config.js.map +1 -0
- package/dist/common-infra/index.d.ts +2 -0
- package/dist/common-infra/index.js +19 -0
- package/dist/common-infra/index.js.map +1 -0
- package/dist/core-common/constant/app.constant.d.ts +2 -0
- package/dist/core-common/constant/app.constant.js +6 -0
- package/dist/core-common/constant/app.constant.js.map +1 -0
- package/dist/core-common/core-common.module.d.ts +4 -0
- package/dist/core-common/core-common.module.js +31 -0
- package/dist/core-common/core-common.module.js.map +1 -0
- package/dist/core-common/error/custom-error/already-exists.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/already-exists.error.js +12 -0
- package/dist/core-common/error/custom-error/already-exists.error.js.map +1 -0
- package/dist/core-common/error/custom-error/bad-request.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/bad-request.error.js +12 -0
- package/dist/core-common/error/custom-error/bad-request.error.js.map +1 -0
- package/dist/core-common/error/custom-error/conflict.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/conflict.error.js +12 -0
- package/dist/core-common/error/custom-error/conflict.error.js.map +1 -0
- package/dist/core-common/error/custom-error/custom-validation-error.d.ts +5 -0
- package/dist/core-common/error/custom-error/custom-validation-error.js +13 -0
- package/dist/core-common/error/custom-error/custom-validation-error.js.map +1 -0
- package/dist/core-common/error/custom-error/forbidden.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/forbidden.error.js +12 -0
- package/dist/core-common/error/custom-error/forbidden.error.js.map +1 -0
- package/dist/core-common/error/custom-error/internal-server.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/internal-server.error.js +12 -0
- package/dist/core-common/error/custom-error/internal-server.error.js.map +1 -0
- package/dist/core-common/error/custom-error/not-found.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/not-found.error.js +12 -0
- package/dist/core-common/error/custom-error/not-found.error.js.map +1 -0
- package/dist/core-common/error/custom-error/service-unavailable.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/service-unavailable.error.js +12 -0
- package/dist/core-common/error/custom-error/service-unavailable.error.js.map +1 -0
- package/dist/core-common/error/custom-error/unauthorized.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/unauthorized.error.js +12 -0
- package/dist/core-common/error/custom-error/unauthorized.error.js.map +1 -0
- package/dist/core-common/error/custom-error/unprocess-entity.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/unprocess-entity.error.js +12 -0
- package/dist/core-common/error/custom-error/unprocess-entity.error.js.map +1 -0
- package/dist/core-common/error/custom-error/validation.error.d.ts +4 -0
- package/dist/core-common/error/custom-error/validation.error.js +12 -0
- package/dist/core-common/error/custom-error/validation.error.js.map +1 -0
- package/dist/core-common/error/generic.error.d.ts +7 -0
- package/dist/core-common/error/generic.error.js +38 -0
- package/dist/core-common/error/generic.error.js.map +1 -0
- package/dist/core-common/error/index.d.ts +10 -0
- package/dist/core-common/error/index.js +27 -0
- package/dist/core-common/error/index.js.map +1 -0
- package/dist/core-common/index.d.ts +12 -0
- package/dist/core-common/index.js +29 -0
- package/dist/core-common/index.js.map +1 -0
- package/dist/core-common/logger/logger.interface.d.ts +7 -0
- package/dist/core-common/logger/logger.interface.js +3 -0
- package/dist/core-common/logger/logger.interface.js.map +1 -0
- package/dist/core-common/logger/logger.module.d.ts +6 -0
- package/dist/core-common/logger/logger.module.js +33 -0
- package/dist/core-common/logger/logger.module.js.map +1 -0
- package/dist/core-common/logger/logger.service.d.ts +29 -0
- package/dist/core-common/logger/logger.service.js +125 -0
- package/dist/core-common/logger/logger.service.js.map +1 -0
- package/dist/core-common/response-model/generic-error-response.model.d.ts +15 -0
- package/dist/core-common/response-model/generic-error-response.model.js +33 -0
- package/dist/core-common/response-model/generic-error-response.model.js.map +1 -0
- package/dist/core-common/response-model/generic-success-response.model.d.ts +8 -0
- package/dist/core-common/response-model/generic-success-response.model.js +17 -0
- package/dist/core-common/response-model/generic-success-response.model.js.map +1 -0
- package/dist/core-common/result-model/result.d.ts +10 -0
- package/dist/core-common/result-model/result.js +38 -0
- package/dist/core-common/result-model/result.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +1 -1
- package/src/common-infra/common-infra.module.ts +15 -7
- package/src/common-infra/database/database.module.ts +20 -12
- package/src/common-infra/index.ts +2 -0
- package/src/core-common/core-common.module.ts +18 -8
- package/src/core-common/index.ts +13 -0
- package/src/core-common/logger/logger.interface.ts +8 -0
- package/src/core-common/logger/logger.module.ts +22 -7
- package/.prettierrc +0 -0
- package/nest-cli.json +0 -8
- package/src/core-common/logger/logger.provider.ts +0 -7
- package/src/middleware/async-storage.middleware.ts +0 -29
- package/src/middleware/filter/global-exeception.filter.ts +0 -117
- package/src/middleware/index.ts +0 -2
- package/src/middleware/interceptor/response-handler.ts +0 -69
- package/src/middleware/platform-auth.middleware.ts +0 -13
- package/src/middleware/utils/http-response.formatter.ts +0 -126
- /package/src/core-common/logger/{index.ts → logger.service.ts} +0 -0
package/package.json
CHANGED
|
@@ -1,9 +1,17 @@
|
|
|
1
|
-
import { Module } from "@nestjs/common";
|
|
1
|
+
import { DynamicModule, Module } from "@nestjs/common";
|
|
2
|
+
import { ConfigModule } from "@nestjs/config";
|
|
2
3
|
import { DBModule } from "./database/database.module";
|
|
3
4
|
|
|
4
|
-
@Module({
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
5
|
+
@Module({})
|
|
6
|
+
export class CommonInfraModule {
|
|
7
|
+
static forRoot(): DynamicModule {
|
|
8
|
+
return {
|
|
9
|
+
module: CommonInfraModule,
|
|
10
|
+
imports: [
|
|
11
|
+
ConfigModule, // assumes consumer app config
|
|
12
|
+
DBModule,
|
|
13
|
+
],
|
|
14
|
+
exports: [DBModule],
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -1,15 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
1
|
+
// src/database/database.module.ts
|
|
2
|
+
import { DynamicModule, Module } from "@nestjs/common";
|
|
3
3
|
import { ConfigModule, ConfigService } from "@nestjs/config";
|
|
4
|
+
import { TypeOrmModule } from "@nestjs/typeorm";
|
|
4
5
|
import { typeOrmConfig } from "./typeorm.config";
|
|
5
6
|
|
|
6
|
-
@Module({
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
7
|
+
@Module({})
|
|
8
|
+
export class DBModule {
|
|
9
|
+
static forRoot(): DynamicModule {
|
|
10
|
+
return {
|
|
11
|
+
module: DBModule,
|
|
12
|
+
imports: [
|
|
13
|
+
TypeOrmModule.forRootAsync({
|
|
14
|
+
imports: [ConfigModule],
|
|
15
|
+
inject: [ConfigService],
|
|
16
|
+
useFactory: (configService: ConfigService) =>
|
|
17
|
+
typeOrmConfig(configService),
|
|
18
|
+
}),
|
|
19
|
+
],
|
|
20
|
+
exports: [TypeOrmModule],
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -1,9 +1,19 @@
|
|
|
1
|
-
|
|
1
|
+
// src/core-common.module.ts
|
|
2
|
+
import { DynamicModule, Global, Module } from "@nestjs/common";
|
|
3
|
+
import { LoggerModule } from "./logger/logger.module";
|
|
2
4
|
|
|
3
|
-
@
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
5
|
+
@Global()
|
|
6
|
+
@Module({})
|
|
7
|
+
export class CoreCommonModule {
|
|
8
|
+
static forRoot(): DynamicModule {
|
|
9
|
+
return {
|
|
10
|
+
module: CoreCommonModule,
|
|
11
|
+
imports: [
|
|
12
|
+
LoggerModule.forRoot(),
|
|
13
|
+
],
|
|
14
|
+
exports: [
|
|
15
|
+
LoggerModule,
|
|
16
|
+
],
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export * from './constant/app.constant'
|
|
2
|
+
export * from './error/custom-error/already-exists.error'
|
|
3
|
+
export * from './error/custom-error/not-found.error'
|
|
4
|
+
export * from './error/custom-error/validation.error'
|
|
5
|
+
export * from './error/custom-error/internal-server.error'
|
|
6
|
+
export * from './error/custom-error/unauthorized.error'
|
|
7
|
+
export * from './error/custom-error/service-unavailable.error'
|
|
8
|
+
export * from './error/generic.error'
|
|
9
|
+
export * from './result-model/result'
|
|
10
|
+
export * from './response-model/generic-error-response.model'
|
|
11
|
+
export * from './response-model/generic-success-response.model'
|
|
12
|
+
|
|
13
|
+
export * from './core-common.module'
|
|
@@ -1,8 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
1
|
+
// src/logger/logger.module.ts
|
|
2
|
+
import { DynamicModule, Module } from "@nestjs/common";
|
|
3
|
+
import { LoggerService } from "./logger.service";
|
|
4
|
+
import { LoggerModuleOptions } from "./logger.interface";
|
|
3
5
|
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
export const LOGGER_OPTIONS = Symbol("LOGGER_OPTIONS");
|
|
7
|
+
|
|
8
|
+
@Module({})
|
|
9
|
+
export class LoggerModule {
|
|
10
|
+
static forRoot(options: LoggerModuleOptions = {}): DynamicModule {
|
|
11
|
+
return {
|
|
12
|
+
module: LoggerModule,
|
|
13
|
+
providers: [
|
|
14
|
+
LoggerService,
|
|
15
|
+
{
|
|
16
|
+
provide: LOGGER_OPTIONS,
|
|
17
|
+
useValue: options,
|
|
18
|
+
},
|
|
19
|
+
],
|
|
20
|
+
exports: [LoggerService],
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
}
|
package/.prettierrc
DELETED
|
File without changes
|
package/nest-cli.json
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
// async-storage.middleware.ts
|
|
2
|
-
import { Injectable, NestMiddleware } from "@nestjs/common";
|
|
3
|
-
import { AsyncLocalStorage } from "async_hooks";
|
|
4
|
-
import { Request, Response, NextFunction } from "express";
|
|
5
|
-
|
|
6
|
-
@Injectable()
|
|
7
|
-
export class AsyncStorageMiddleware implements NestMiddleware {
|
|
8
|
-
private static storage = new AsyncLocalStorage<Map<string, any>>();
|
|
9
|
-
|
|
10
|
-
static get(key: string): any {
|
|
11
|
-
const store = AsyncStorageMiddleware.storage.getStore();
|
|
12
|
-
return store?.get(key);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
static set(key: string, value: any): void {
|
|
16
|
-
const store = AsyncStorageMiddleware.storage.getStore();
|
|
17
|
-
if (store) {
|
|
18
|
-
store.set(key, value);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
use(req: Request, _res: Response, next: NextFunction) {
|
|
23
|
-
const store = new Map<string, any>();
|
|
24
|
-
store.set("request", req);
|
|
25
|
-
AsyncStorageMiddleware.storage.run(store, () => {
|
|
26
|
-
next();
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
}
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
ArgumentsHost,
|
|
3
|
-
Catch,
|
|
4
|
-
ExceptionFilter,
|
|
5
|
-
HttpException,
|
|
6
|
-
HttpStatus,
|
|
7
|
-
} from "@nestjs/common";
|
|
8
|
-
import { Response } from "express";
|
|
9
|
-
import { GenericError } from "../../core-common/error";
|
|
10
|
-
import { CustomValidationError } from "../../core-common/error/custom-error/custom-validation-error";
|
|
11
|
-
import { Result } from "../../core-common/result-model/result";
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Handles and processes exceptions, providing standardized error responses.
|
|
15
|
-
* This global exception handler can be used to catch and respond to exceptions thrown
|
|
16
|
-
* during HTTP requests and format responses accordingly.
|
|
17
|
-
*/
|
|
18
|
-
|
|
19
|
-
@Catch()
|
|
20
|
-
export class GlobalExceptionHandler implements ExceptionFilter {
|
|
21
|
-
catch(exception: unknown, host: ArgumentsHost) {
|
|
22
|
-
const response = host.switchToHttp().getResponse<Response>();
|
|
23
|
-
|
|
24
|
-
/* 1️⃣ Domain Result (highest priority) */
|
|
25
|
-
if (exception instanceof Result) {
|
|
26
|
-
const statusCode =
|
|
27
|
-
exception.error?.statusCode ?? HttpStatus.INTERNAL_SERVER_ERROR;
|
|
28
|
-
|
|
29
|
-
const payload: any = {
|
|
30
|
-
statusCode,
|
|
31
|
-
success: false,
|
|
32
|
-
error: {
|
|
33
|
-
code: exception.error?.code ?? "ERROR",
|
|
34
|
-
message: exception.error?.message ?? "An error occurred",
|
|
35
|
-
},
|
|
36
|
-
timestamp: exception.timestamp ?? new Date().toISOString(),
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
if (exception.data !== undefined && exception.data !== null) {
|
|
40
|
-
payload.data = exception.data;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return response.status(statusCode).json(payload);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/* 2️⃣ Custom domain errors */
|
|
47
|
-
if (exception instanceof GenericError) {
|
|
48
|
-
return response.status(exception.statusCode).json({
|
|
49
|
-
statusCode: exception.statusCode,
|
|
50
|
-
success: false,
|
|
51
|
-
error: {
|
|
52
|
-
code: exception.code,
|
|
53
|
-
message: exception.message,
|
|
54
|
-
},
|
|
55
|
-
timestamp: new Date().toISOString(),
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
/* 3️⃣ NestJS HTTP exceptions */
|
|
60
|
-
if (exception instanceof HttpException) {
|
|
61
|
-
const status = exception.getStatus();
|
|
62
|
-
const res = exception.getResponse();
|
|
63
|
-
|
|
64
|
-
const isValidationPipeError = exception.stack?.includes("ValidationPipe");
|
|
65
|
-
|
|
66
|
-
if (isValidationPipeError) {
|
|
67
|
-
const validationErrors = new CustomValidationError(res);
|
|
68
|
-
return response.status(validationErrors.statusCode).json({
|
|
69
|
-
success: false,
|
|
70
|
-
error: {
|
|
71
|
-
code: validationErrors.code,
|
|
72
|
-
message: validationErrors.message,
|
|
73
|
-
validationError: validationErrors.validationErrors,
|
|
74
|
-
},
|
|
75
|
-
timestamp: new Date().toISOString(),
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return response.status(status).json({
|
|
80
|
-
statusCode: status,
|
|
81
|
-
success: false,
|
|
82
|
-
error: {
|
|
83
|
-
code: "HTTP_EXCEPTION",
|
|
84
|
-
message:
|
|
85
|
-
typeof res === "string"
|
|
86
|
-
? res
|
|
87
|
-
: ((res as any).message ?? exception.message),
|
|
88
|
-
},
|
|
89
|
-
timestamp: new Date().toISOString(),
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/* 4️⃣ Native JS errors (TypeError, Error, etc.) */
|
|
94
|
-
if (exception instanceof Error) {
|
|
95
|
-
return response.status(HttpStatus.INTERNAL_SERVER_ERROR).json({
|
|
96
|
-
statusCode: HttpStatus.INTERNAL_SERVER_ERROR,
|
|
97
|
-
success: false,
|
|
98
|
-
error: {
|
|
99
|
-
code: exception.name,
|
|
100
|
-
message: exception.message,
|
|
101
|
-
},
|
|
102
|
-
timestamp: new Date().toISOString(),
|
|
103
|
-
});
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
/* 5️⃣ Truly unknown (non-Error throwables) */
|
|
107
|
-
return response.status(HttpStatus.INTERNAL_SERVER_ERROR).json({
|
|
108
|
-
statusCode: HttpStatus.INTERNAL_SERVER_ERROR,
|
|
109
|
-
success: false,
|
|
110
|
-
error: {
|
|
111
|
-
code: "UNKNOWN_ERROR",
|
|
112
|
-
message: "Internal server error",
|
|
113
|
-
},
|
|
114
|
-
timestamp: new Date().toISOString(),
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
}
|
package/src/middleware/index.ts
DELETED
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CallHandler,
|
|
3
|
-
ExecutionContext,
|
|
4
|
-
Injectable,
|
|
5
|
-
NestInterceptor,
|
|
6
|
-
} from "@nestjs/common";
|
|
7
|
-
import { ServerResponse } from "http";
|
|
8
|
-
import { Observable } from "rxjs";
|
|
9
|
-
import { GenericErrorResponse } from "../../core-common/response-model/generic-error-response.model";
|
|
10
|
-
import { GenericSuccessResponse } from "../../core-common/response-model/generic-success-response.model";
|
|
11
|
-
import { Result } from "../../core-common/result-model/result";
|
|
12
|
-
import { HttpResponseFormatter } from "../utils/http-response.formatter";
|
|
13
|
-
import { LoggerService } from "@core-common/logger";
|
|
14
|
-
/**
|
|
15
|
-
* Intercepts the response and returns a standard ApiReponse object
|
|
16
|
-
*/
|
|
17
|
-
@Injectable()
|
|
18
|
-
export class ResponseHandler implements NestInterceptor {
|
|
19
|
-
constructor(
|
|
20
|
-
private readonly logger: LoggerService
|
|
21
|
-
) {}
|
|
22
|
-
|
|
23
|
-
intercept(exContext: ExecutionContext, next: CallHandler): Observable<any> {
|
|
24
|
-
return new Observable((subscriber) => {
|
|
25
|
-
next.handle().subscribe({
|
|
26
|
-
next: (data) => {
|
|
27
|
-
const mapped = this.handleResponse(exContext, data);
|
|
28
|
-
subscriber.next(mapped);
|
|
29
|
-
},
|
|
30
|
-
error: (err) => {
|
|
31
|
-
this.logger.error('Error in ResponseHandler Interceptor', err);
|
|
32
|
-
subscriber.error(err);
|
|
33
|
-
},
|
|
34
|
-
complete: () => {
|
|
35
|
-
subscriber.complete();
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Checks the response content and appropriately sets the status code and wraps the return value in a ApiErroReponse or a
|
|
43
|
-
* ApiSuccessReponse
|
|
44
|
-
* @param excecutionContext - Instance of the executionContext object
|
|
45
|
-
* @param result Data returned by the controller method
|
|
46
|
-
* @returns - Instance of ApiSuccessReponse or ApiErrorReponse
|
|
47
|
-
*/
|
|
48
|
-
private handleResponse(
|
|
49
|
-
excecutionContext: ExecutionContext,
|
|
50
|
-
result: Result<any>,
|
|
51
|
-
): GenericSuccessResponse<any> | GenericErrorResponse {
|
|
52
|
-
let serverResponse = excecutionContext
|
|
53
|
-
.switchToHttp()
|
|
54
|
-
.getResponse<ServerResponse>();
|
|
55
|
-
|
|
56
|
-
const apiReponse: any = new HttpResponseFormatter().getStandardApiResponse(
|
|
57
|
-
serverResponse.statusCode,
|
|
58
|
-
result,
|
|
59
|
-
);
|
|
60
|
-
serverResponse.statusCode = apiReponse.statusCode
|
|
61
|
-
? apiReponse.statusCode
|
|
62
|
-
: apiReponse?.error?.statusCode;
|
|
63
|
-
serverResponse[`statusCode`] = serverResponse.statusCode;
|
|
64
|
-
if (apiReponse?.statusCode) {
|
|
65
|
-
delete apiReponse?.error?.statusCode;
|
|
66
|
-
}
|
|
67
|
-
return apiReponse;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Injectable, NestMiddleware } from "@nestjs/common";
|
|
2
|
-
import { Request, Response } from "express";
|
|
3
|
-
|
|
4
|
-
@Injectable()
|
|
5
|
-
export class AuthMiddleware implements NestMiddleware<Request, Response> {
|
|
6
|
-
use(req: Request, _res: Response, next: () => void): void {
|
|
7
|
-
const authHeader = req.headers["authorization"];
|
|
8
|
-
// Implement your authentication logic here
|
|
9
|
-
// For example, validate JWT token from authHeader
|
|
10
|
-
console.log("Auth Middleware executed", authHeader);
|
|
11
|
-
next();
|
|
12
|
-
}
|
|
13
|
-
}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import { HttpStatus } from "@nestjs/common";
|
|
2
|
-
import { AlreadyExistsError } from "../../core-common/error/custom-error/already-exists.error";
|
|
3
|
-
import { GenericError } from "../../core-common/error/generic.error";
|
|
4
|
-
import { GenericErrorResponse } from "../../core-common/response-model/generic-error-response.model";
|
|
5
|
-
import { GenericSuccessResponse } from "../../core-common/response-model/generic-success-response.model";
|
|
6
|
-
import { Result } from "../../core-common/result-model/result";
|
|
7
|
-
import { BadRequestError, ConflictError, ForbiddenError, NotFoundError, ServiceUnavailableError, UnauthorizedError, UnprocessableEntityError, ValidationError } from "../../core-common/error";
|
|
8
|
-
import { InternalServerError } from "../../core-common/error/custom-error/internal-server.error";
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Helps in returning a appropriate and standard Response format based on success or error scenario
|
|
12
|
-
*/
|
|
13
|
-
export class HttpResponseFormatter {
|
|
14
|
-
constructor() {}
|
|
15
|
-
/**
|
|
16
|
-
* Returns a standard formatted ApiSuccesReponse or ApiErrorResponse depending on the response data
|
|
17
|
-
* @param statusCode - Http Status code
|
|
18
|
-
* @param responseData - Response value from the api controller method
|
|
19
|
-
*/
|
|
20
|
-
public getStandardApiResponse(
|
|
21
|
-
statusCode: number,
|
|
22
|
-
responseData: any,
|
|
23
|
-
): GenericSuccessResponse<any> | GenericErrorResponse {
|
|
24
|
-
if (this.isSuccessfulResult(responseData)) {
|
|
25
|
-
return this.getSuccessResponse(responseData, statusCode);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
if (this.isFailedResult(responseData)) {
|
|
29
|
-
return this.getFailureResponse(responseData);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
return responseData;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
*
|
|
37
|
-
* @param responseData Initializes and returns the success api response
|
|
38
|
-
* @param statusCode - Http Status code
|
|
39
|
-
* @returns - instance of ApiSuccessResponse object
|
|
40
|
-
*/
|
|
41
|
-
private getSuccessResponse(
|
|
42
|
-
responseData: any,
|
|
43
|
-
statusCode: number,
|
|
44
|
-
): GenericSuccessResponse<any> {
|
|
45
|
-
const apiSuccessResponse = new GenericSuccessResponse();
|
|
46
|
-
apiSuccessResponse.initialize(responseData, statusCode);
|
|
47
|
-
return apiSuccessResponse;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* Checks if the the data is of type Result and is successful
|
|
52
|
-
* @param responseData - response data
|
|
53
|
-
* @returns - boolean
|
|
54
|
-
*/
|
|
55
|
-
private isSuccessfulResult(responseData: any): boolean {
|
|
56
|
-
return responseData instanceof Result && responseData.success;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* Checks if the the data is of type Result and is successful
|
|
61
|
-
* @param responseData - response data
|
|
62
|
-
* @returns - boolean
|
|
63
|
-
*/
|
|
64
|
-
private isFailedResult(responseData: any): boolean {
|
|
65
|
-
return responseData instanceof Result && !responseData.success;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Gets the failure response based on the result contents
|
|
70
|
-
* @param result - Result object returned from the controller method
|
|
71
|
-
*/
|
|
72
|
-
private getFailureResponse(result: Result<any>) {
|
|
73
|
-
const statusCode = this.getStatusCode(result.error);
|
|
74
|
-
const apiErrorResponse = new GenericErrorResponse();
|
|
75
|
-
apiErrorResponse.initialize(result, statusCode);
|
|
76
|
-
return apiErrorResponse;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
private getStatusCode(error: GenericError): number {
|
|
80
|
-
if (error instanceof BadRequestError) {
|
|
81
|
-
return HttpStatus.BAD_REQUEST;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
if (error instanceof UnauthorizedError) {
|
|
85
|
-
return HttpStatus.UNAUTHORIZED;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
if (error instanceof ForbiddenError) {
|
|
89
|
-
return HttpStatus.FORBIDDEN;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
if (error instanceof NotFoundError) {
|
|
93
|
-
return HttpStatus.NOT_FOUND;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
if (error instanceof AlreadyExistsError) {
|
|
97
|
-
return HttpStatus.CONFLICT;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
if (error instanceof ConflictError) {
|
|
101
|
-
return HttpStatus.CONFLICT;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (error instanceof ValidationError) {
|
|
105
|
-
return HttpStatus.UNPROCESSABLE_ENTITY;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
if (error instanceof UnprocessableEntityError) {
|
|
109
|
-
return HttpStatus.UNPROCESSABLE_ENTITY;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
if (error instanceof ServiceUnavailableError) {
|
|
113
|
-
return HttpStatus.SERVICE_UNAVAILABLE;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
if (error instanceof InternalServerError) {
|
|
117
|
-
return HttpStatus.INTERNAL_SERVER_ERROR;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
if (error instanceof GenericError) {
|
|
121
|
-
return error.statusCode;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
return HttpStatus.INTERNAL_SERVER_ERROR;
|
|
125
|
-
}
|
|
126
|
-
}
|
|
File without changes
|