@russ-b/nestjs-common-tools 1.1.7 → 1.1.9
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/grpc/filters/typeorm-exception.filter.d.ts +6 -0
- package/dist/common/grpc/filters/typeorm-exception.filter.js +52 -0
- package/dist/common/grpc/filters/typeorm-exception.filter.js.map +1 -0
- package/dist/common/grpc/interceptors/index.d.ts +1 -0
- package/dist/common/grpc/interceptors/index.js +18 -0
- package/dist/common/grpc/interceptors/index.js.map +1 -0
- package/dist/common/grpc/interceptors/struct.interceptor.d.ts +6 -0
- package/dist/common/grpc/interceptors/struct.interceptor.js +42 -0
- package/dist/common/grpc/interceptors/struct.interceptor.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -1
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ExceptionFilter, ArgumentsHost } from '@nestjs/common';
|
|
2
|
+
import { QueryFailedError } from 'typeorm';
|
|
3
|
+
export declare class TypeOrmExceptionFilter implements ExceptionFilter {
|
|
4
|
+
catch(exception: QueryFailedError, host: ArgumentsHost): import("rxjs").Observable<never> | undefined;
|
|
5
|
+
private getError;
|
|
6
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
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.TypeOrmExceptionFilter = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const typeorm_1 = require("typeorm");
|
|
12
|
+
const grpc_js_1 = require("@grpc/grpc-js");
|
|
13
|
+
const rxjs_1 = require("rxjs");
|
|
14
|
+
let TypeOrmExceptionFilter = class TypeOrmExceptionFilter {
|
|
15
|
+
catch(exception, host) {
|
|
16
|
+
if (host.getType() !== 'rpc') {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const errno = exception.errno || +exception.code;
|
|
20
|
+
const error = this.getError(errno);
|
|
21
|
+
return (0, rxjs_1.throwError)(() => ({
|
|
22
|
+
code: error?.code || 500,
|
|
23
|
+
message: error?.message || exception.message,
|
|
24
|
+
}));
|
|
25
|
+
}
|
|
26
|
+
getError(code) {
|
|
27
|
+
const errorMapping = {
|
|
28
|
+
23505: {
|
|
29
|
+
code: grpc_js_1.status.ALREADY_EXISTS,
|
|
30
|
+
message: 'A record with these unique constraints already exists',
|
|
31
|
+
},
|
|
32
|
+
1062: {
|
|
33
|
+
code: grpc_js_1.status.ALREADY_EXISTS,
|
|
34
|
+
message: 'A record with these unique constraints already exists',
|
|
35
|
+
},
|
|
36
|
+
1451: {
|
|
37
|
+
code: grpc_js_1.status.ALREADY_EXISTS,
|
|
38
|
+
message: 'Cannot delete or update a parent row: a foreign key constraint fails',
|
|
39
|
+
},
|
|
40
|
+
1452: {
|
|
41
|
+
code: grpc_js_1.status.INVALID_ARGUMENT,
|
|
42
|
+
message: 'Cannot add or update a child row: a foreign key constraint fails',
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
return errorMapping[code];
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.TypeOrmExceptionFilter = TypeOrmExceptionFilter;
|
|
49
|
+
exports.TypeOrmExceptionFilter = TypeOrmExceptionFilter = __decorate([
|
|
50
|
+
(0, common_1.Catch)(typeorm_1.QueryFailedError)
|
|
51
|
+
], TypeOrmExceptionFilter);
|
|
52
|
+
//# sourceMappingURL=typeorm-exception.filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeorm-exception.filter.js","sourceRoot":"","sources":["../../../../src/common/grpc/filters/typeorm-exception.filter.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuE;AACvE,qCAA2C;AAC3C,2CAAuC;AACvC,+BAAkC;AAQ3B,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IACjC,KAAK,CAAC,SAA2B,EAAE,IAAmB;QACpD,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,KAAK,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAI,SAAiB,CAAC,KAAK,IAAI,CAAE,SAAiB,CAAC,IAAI,CAAC;QACnE,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnC,OAAO,IAAA,iBAAU,EAAC,GAAG,EAAE,CAAC,CAAC;YACvB,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,GAAG;YACxB,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,SAAS,CAAC,OAAO;SAC7C,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,QAAQ,CAAC,IAAY;QAC3B,MAAM,YAAY,GAA2B;YAC3C,KAAK,EAAE;gBACL,IAAI,EAAE,gBAAM,CAAC,cAAc;gBAC3B,OAAO,EAAE,uDAAuD;aACjE;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,gBAAM,CAAC,cAAc;gBAC3B,OAAO,EAAE,uDAAuD;aACjE;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,gBAAM,CAAC,cAAc;gBAC3B,OAAO,EACL,sEAAsE;aACzE;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,gBAAM,CAAC,gBAAgB;gBAC7B,OAAO,EACL,kEAAkE;aACrE;SACF,CAAC;QAEF,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;CACF,CAAA;AAtCY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,cAAK,EAAC,0BAAgB,CAAC;GACX,sBAAsB,CAsClC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './struct.interceptor';
|
|
@@ -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("./struct.interceptor"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/common/grpc/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAoC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { CallHandler, ExecutionContext, NestInterceptor } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
export declare class StructInterceptor implements NestInterceptor {
|
|
4
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
5
|
+
private traverseAndTransform;
|
|
6
|
+
}
|
|
@@ -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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.StructInterceptor = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const transformers_1 = require("../transformers");
|
|
12
|
+
let StructInterceptor = class StructInterceptor {
|
|
13
|
+
intercept(context, next) {
|
|
14
|
+
const grpcContext = context.switchToRpc();
|
|
15
|
+
context.getArgs()[0] = this.traverseAndTransform(grpcContext.getData());
|
|
16
|
+
return next.handle();
|
|
17
|
+
}
|
|
18
|
+
traverseAndTransform(obj) {
|
|
19
|
+
if (typeof obj !== 'object' || obj === null) {
|
|
20
|
+
return obj;
|
|
21
|
+
}
|
|
22
|
+
if (Array.isArray(obj)) {
|
|
23
|
+
return obj.map(this.traverseAndTransform);
|
|
24
|
+
}
|
|
25
|
+
const transformedObj = {};
|
|
26
|
+
for (const key in obj) {
|
|
27
|
+
const value = obj[key];
|
|
28
|
+
if (value && transformers_1.StructTransformer.isStruct(value)) {
|
|
29
|
+
transformedObj[key] = transformers_1.StructTransformer.toObject(value);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
transformedObj[key] = this.traverseAndTransform(value);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return transformedObj;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
exports.StructInterceptor = StructInterceptor;
|
|
39
|
+
exports.StructInterceptor = StructInterceptor = __decorate([
|
|
40
|
+
(0, common_1.Injectable)()
|
|
41
|
+
], StructInterceptor);
|
|
42
|
+
//# sourceMappingURL=struct.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"struct.interceptor.js","sourceRoot":"","sources":["../../../../src/common/grpc/interceptors/struct.interceptor.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAKwB;AAExB,kDAAoD;AAG7C,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACpD,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;QAE1C,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QAExE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;IAEO,oBAAoB,CAAC,GAAQ;QACnC,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YAC5C,OAAO,GAAG,CAAC;QACb,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACvB,OAAO,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC5C,CAAC;QAED,MAAM,cAAc,GAAwB,EAAE,CAAC;QAC/C,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;YACtB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YAGvB,IAAI,KAAK,IAAI,gCAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC/C,cAAc,CAAC,GAAG,CAAC,GAAG,gCAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC1D,CAAC;iBAAM,CAAC;gBACN,cAAc,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YACzD,CAAC;QACH,CAAC;QAED,OAAO,cAAc,CAAC;IACxB,CAAC;CACF,CAAA;AAhCY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;GACA,iBAAiB,CAgC7B"}
|