@saihu/common 1.1.64 → 1.1.66

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.
@@ -2,6 +2,7 @@ import { ArgumentsHost } from '@nestjs/common';
2
2
  import { BaseRpcExceptionFilter } from '@nestjs/microservices';
3
3
  export declare class BaseErrorRpcFilter extends BaseRpcExceptionFilter {
4
4
  private readonly logger;
5
+ constructor();
5
6
  catch(exception: any, host: ArgumentsHost): import("rxjs").Observable<any>;
6
7
  }
7
8
  //# sourceMappingURL=base-error-rpc.filter.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"base-error-rpc.filter.d.ts","sourceRoot":"","sources":["../../src/filters/base-error-rpc.filter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAiB,MAAM,gBAAgB,CAAC;AAC9D,OAAO,EAAE,sBAAsB,EAAgB,MAAM,uBAAuB,CAAC;AAG7E,qBACa,kBAAmB,SAAQ,sBAAsB;IAC5D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuC;IAE9D,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,IAAI,EAAE,aAAa;CAuD1C"}
1
+ {"version":3,"file":"base-error-rpc.filter.d.ts","sourceRoot":"","sources":["../../src/filters/base-error-rpc.filter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAiB,MAAM,gBAAgB,CAAC;AAC9D,OAAO,EAAE,sBAAsB,EAAgB,MAAM,uBAAuB,CAAC;AAG7E,qBACa,kBAAmB,SAAQ,sBAAsB;IAC5D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuC;;IAQ9D,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,IAAI,EAAE,aAAa;CAuD1C"}
@@ -5,6 +5,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
5
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
6
  return c > 3 && r && Object.defineProperty(target, key, r), r;
7
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
+ };
8
11
  var BaseErrorRpcFilter_1;
9
12
  Object.defineProperty(exports, "__esModule", { value: true });
10
13
  exports.BaseErrorRpcFilter = void 0;
@@ -14,8 +17,10 @@ const microservices_1 = require("@nestjs/microservices");
14
17
  const base_res_dto_1 = require("../dto/base-res.dto");
15
18
  let BaseErrorRpcFilter = BaseErrorRpcFilter_1 = class BaseErrorRpcFilter extends microservices_1.BaseRpcExceptionFilter {
16
19
  constructor() {
17
- super(...arguments);
20
+ super();
18
21
  this.logger = new common_1.Logger(BaseErrorRpcFilter_1.name);
22
+ console.log('!!! BaseErrorRpcFilter CONSTRUCTOR CALLED !!!');
23
+ this.logger.log('BaseErrorRpcFilter initialized');
19
24
  }
20
25
  catch(exception, host) {
21
26
  var _a, _b;
@@ -64,4 +69,6 @@ let BaseErrorRpcFilter = BaseErrorRpcFilter_1 = class BaseErrorRpcFilter extends
64
69
  exports.BaseErrorRpcFilter = BaseErrorRpcFilter;
65
70
  exports.BaseErrorRpcFilter = BaseErrorRpcFilter = BaseErrorRpcFilter_1 = __decorate([
66
71
  (0, common_1.Catch)() // Catch everything
72
+ ,
73
+ __metadata("design:paramtypes", [])
67
74
  ], BaseErrorRpcFilter);
@@ -1,3 +1,4 @@
1
1
  export * from './transform.interceptor';
2
2
  export * from './operlog.interceptor';
3
+ export * from './rpc-error.interceptor';
3
4
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/interceptors/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/interceptors/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC"}
@@ -16,3 +16,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./transform.interceptor"), exports);
18
18
  __exportStar(require("./operlog.interceptor"), exports);
19
+ __exportStar(require("./rpc-error.interceptor"), exports);
@@ -0,0 +1,7 @@
1
+ import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
+ import { Observable } from 'rxjs';
3
+ export declare class RpcErrorInterceptor implements NestInterceptor {
4
+ private readonly logger;
5
+ intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
6
+ }
7
+ //# sourceMappingURL=rpc-error.interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rpc-error.interceptor.d.ts","sourceRoot":"","sources":["../../src/interceptors/rpc-error.interceptor.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,eAAe,EACf,gBAAgB,EAChB,WAAW,EAEZ,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAc,MAAM,MAAM,CAAC;AAK9C,qBACa,mBAAoB,YAAW,eAAe;IACzD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwC;IAE/D,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,GAAG,CAAC;CA4CzE"}
@@ -0,0 +1,59 @@
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 RpcErrorInterceptor_1;
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.RpcErrorInterceptor = void 0;
11
+ // @saihu/common/src/interceptors/rpc-error.interceptor.ts
12
+ const common_1 = require("@nestjs/common");
13
+ const rxjs_1 = require("rxjs");
14
+ const operators_1 = require("rxjs/operators");
15
+ const microservices_1 = require("@nestjs/microservices");
16
+ const base_res_dto_1 = require("../dto/base-res.dto");
17
+ let RpcErrorInterceptor = RpcErrorInterceptor_1 = class RpcErrorInterceptor {
18
+ constructor() {
19
+ this.logger = new common_1.Logger(RpcErrorInterceptor_1.name);
20
+ }
21
+ intercept(context, next) {
22
+ // Only intercept RPC context
23
+ if (context.getType() !== 'rpc') {
24
+ return next.handle();
25
+ }
26
+ return next.handle().pipe((0, operators_1.catchError)((error) => {
27
+ var _a, _b;
28
+ this.logger.debug('RPC error caught by interceptor:', {
29
+ type: (_a = error === null || error === void 0 ? void 0 : error.constructor) === null || _a === void 0 ? void 0 : _a.name,
30
+ message: error === null || error === void 0 ? void 0 : error.message,
31
+ });
32
+ // Transform BaseError to RpcException
33
+ if (error instanceof base_res_dto_1.BaseError) {
34
+ const payload = {
35
+ code: error.code,
36
+ msg: error.message,
37
+ data: (_b = error.data) !== null && _b !== void 0 ? _b : null,
38
+ };
39
+ this.logger.warn(`BaseError transformed: [${payload.code}] ${payload.msg}`);
40
+ return (0, rxjs_1.throwError)(() => new microservices_1.RpcException(payload));
41
+ }
42
+ // Already an RpcException, pass through
43
+ if (error instanceof microservices_1.RpcException) {
44
+ return (0, rxjs_1.throwError)(() => error);
45
+ }
46
+ // Transform other errors to generic RpcException
47
+ this.logger.error('Unhandled RPC error:', error);
48
+ return (0, rxjs_1.throwError)(() => new microservices_1.RpcException({
49
+ code: 500,
50
+ msg: (error === null || error === void 0 ? void 0 : error.message) || 'Internal server error',
51
+ data: null,
52
+ }));
53
+ }));
54
+ }
55
+ };
56
+ exports.RpcErrorInterceptor = RpcErrorInterceptor;
57
+ exports.RpcErrorInterceptor = RpcErrorInterceptor = RpcErrorInterceptor_1 = __decorate([
58
+ (0, common_1.Injectable)()
59
+ ], RpcErrorInterceptor);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@saihu/common",
3
- "version": "1.1.64",
3
+ "version": "1.1.66",
4
4
  "description": "Common utilities for NestJS applications",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",