@rafikidota/iroh 0.46.0 → 0.47.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.
Files changed (26) hide show
  1. package/dist/common/decorators/generic-delete.decorator.js +2 -1
  2. package/dist/common/decorators/generic-delete.decorator.js.map +1 -1
  3. package/dist/common/decorators/generic-get-by-id.decorator.js +2 -1
  4. package/dist/common/decorators/generic-get-by-id.decorator.js.map +1 -1
  5. package/dist/common/decorators/generic-get.decorator.js +2 -1
  6. package/dist/common/decorators/generic-get.decorator.js.map +1 -1
  7. package/dist/common/decorators/generic-patch.decorator.js +2 -1
  8. package/dist/common/decorators/generic-patch.decorator.js.map +1 -1
  9. package/dist/common/decorators/generic-post.decorator.js +2 -1
  10. package/dist/common/decorators/generic-post.decorator.js.map +1 -1
  11. package/dist/common/decorators/handle-response.decorator.d.ts +7 -0
  12. package/dist/common/decorators/handle-response.decorator.js +36 -0
  13. package/dist/common/decorators/handle-response.decorator.js.map +1 -0
  14. package/dist/common/decorators/index.d.ts +1 -0
  15. package/dist/common/decorators/index.js +1 -0
  16. package/dist/common/decorators/index.js.map +1 -1
  17. package/dist/common/interfaces/exception-mapper.d.ts +5 -0
  18. package/dist/common/interfaces/exception-mapper.js +3 -0
  19. package/dist/common/interfaces/exception-mapper.js.map +1 -0
  20. package/dist/common/interfaces/index.d.ts +1 -0
  21. package/dist/common/interfaces/index.js +1 -0
  22. package/dist/common/interfaces/index.js.map +1 -1
  23. package/dist/core/app/response-handler.d.ts +3 -2
  24. package/dist/core/app/response-handler.js +8 -2
  25. package/dist/core/app/response-handler.js.map +1 -1
  26. package/package.json +9 -9
@@ -4,10 +4,11 @@ exports.Delete = Delete;
4
4
  const common_1 = require("@nestjs/common");
5
5
  const common_2 = require("@nestjs/common");
6
6
  const swagger_1 = require("@nestjs/swagger");
7
+ const handle_response_decorator_1 = require("./handle-response.decorator");
7
8
  function Delete() {
8
9
  return (0, common_1.applyDecorators)((0, common_2.Delete)(':id'), (0, swagger_1.ApiResponse)({
9
10
  status: 204,
10
11
  description: `Entity was deleted successfully`,
11
- }), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_1.HttpCode)(204));
12
+ }), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, handle_response_decorator_1.HandleResponse)(), (0, common_1.HttpCode)(204));
12
13
  }
13
14
  //# sourceMappingURL=generic-delete.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generic-delete.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-delete.decorator.ts"],"names":[],"mappings":";;AAIA,wBAaC;AAjBD,2CAA2D;AAC3D,2CAAsD;AACtD,6CAA8C;AAE9C,SAAgB,MAAM;IACpB,OAAO,IAAA,wBAAe,EACpB,IAAA,eAAU,EAAC,KAAK,CAAC,EACjB,IAAA,qBAAW,EAAC;QACV,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,iCAAiC;KAC/C,CAAC,EACF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,GAAG,CAAC,CACd,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"generic-delete.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-delete.decorator.ts"],"names":[],"mappings":";;AAKA,wBAcC;AAnBD,2CAA2D;AAC3D,2CAAsD;AACtD,6CAA8C;AAC9C,2EAA6D;AAE7D,SAAgB,MAAM;IACpB,OAAO,IAAA,wBAAe,EACpB,IAAA,eAAU,EAAC,KAAK,CAAC,EACjB,IAAA,qBAAW,EAAC;QACV,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,iCAAiC;KAC/C,CAAC,EACF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,0CAAc,GAAE,EAChB,IAAA,iBAAQ,EAAC,GAAG,CAAC,CACd,CAAC;AACJ,CAAC"}
@@ -7,8 +7,9 @@ const swagger_1 = require("@nestjs/swagger");
7
7
  const validation_pipe_1 = require("../pipes/validation.pipe");
8
8
  const search_dto_1 = require("../dto/search.dto");
9
9
  const entity_response_decorator_1 = require("./entity-response.decorator");
10
+ const handle_response_decorator_1 = require("./handle-response.decorator");
10
11
  const description = `Entity found by id`;
11
12
  function GetById(View) {
12
- return (0, common_1.applyDecorators)((0, common_2.Get)(':id'), (0, swagger_1.ApiQuery)({ name: 'options', type: String, required: false }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)));
13
+ return (0, common_1.applyDecorators)((0, common_2.Get)(':id'), (0, swagger_1.ApiQuery)({ name: 'options', type: String, required: false }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)), (0, handle_response_decorator_1.HandleResponse)());
13
14
  }
14
15
  //# sourceMappingURL=generic-get-by-id.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generic-get-by-id.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get-by-id.decorator.ts"],"names":[],"mappings":";;AAUA,0BAWC;AArBD,2CAAuD;AACvD,2CAA+C;AAC/C,6CAAwD;AACxD,8DAAiE;AAEjE,kDAA8C;AAC9C,2EAA6D;AAE7D,MAAM,WAAW,GAAG,oBAAoB,CAAC;AAEzC,SAAgB,OAAO,CAAI,IAAa;IACtC,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAG,EAAC,KAAK,CAAC,EACV,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC5D,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"generic-get-by-id.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get-by-id.decorator.ts"],"names":[],"mappings":";;AAWA,0BAYC;AAvBD,2CAAuD;AACvD,2CAA+C;AAC/C,6CAAwD;AACxD,8DAAiE;AAEjE,kDAA8C;AAC9C,2EAA6D;AAC7D,2EAA6D;AAE7D,MAAM,WAAW,GAAG,oBAAoB,CAAC;AAEzC,SAAgB,OAAO,CAAI,IAAa;IACtC,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAG,EAAC,KAAK,CAAC,EACV,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC5D,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,EAC1C,IAAA,0CAAc,GAAE,CACjB,CAAC;AACJ,CAAC"}
@@ -7,7 +7,8 @@ const swagger_1 = require("@nestjs/swagger");
7
7
  const pagination_decorator_1 = require("./pagination.decorator");
8
8
  const validation_pipe_1 = require("../pipes/validation.pipe");
9
9
  const search_dto_1 = require("../dto/search.dto");
10
+ const handle_response_decorator_1 = require("./handle-response.decorator");
10
11
  function Get(View) {
11
- return (0, common_1.applyDecorators)((0, common_2.Get)(), (0, swagger_1.ApiQuery)({ name: 'page', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'limit', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'offset', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'options', type: String, required: false }), (0, pagination_decorator_1.PaginationResponse)(View), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)));
12
+ return (0, common_1.applyDecorators)((0, common_2.Get)(), (0, swagger_1.ApiQuery)({ name: 'page', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'limit', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'offset', type: Number, required: false }), (0, swagger_1.ApiQuery)({ name: 'options', type: String, required: false }), (0, pagination_decorator_1.PaginationResponse)(View), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)), (0, handle_response_decorator_1.HandleResponse)());
12
13
  }
13
14
  //# sourceMappingURL=generic-get.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generic-get.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get.decorator.ts"],"names":[],"mappings":";;AAQA,kBAaC;AArBD,2CAAuD;AACvD,2CAA0D;AAC1D,6CAAwD;AAExD,iEAA4D;AAC5D,8DAAiE;AACjE,kDAA8C;AAE9C,SAAgB,GAAG,CAAI,IAAa;IAClC,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAO,GAAE,EACT,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EACzD,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC1D,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC3D,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC5D,IAAA,yCAAkB,EAAC,IAAI,CAAC,EACxB,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"generic-get.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get.decorator.ts"],"names":[],"mappings":";;AASA,kBAcC;AAvBD,2CAAuD;AACvD,2CAA0D;AAC1D,6CAAwD;AAExD,iEAA4D;AAC5D,8DAAiE;AACjE,kDAA8C;AAC9C,2EAA6D;AAE7D,SAAgB,GAAG,CAAI,IAAa;IAClC,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAO,GAAE,EACT,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EACzD,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC1D,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC3D,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,EAC5D,IAAA,yCAAkB,EAAC,IAAI,CAAC,EACxB,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,EAC1C,IAAA,0CAAc,GAAE,CACjB,CAAC;AACJ,CAAC"}
@@ -6,8 +6,9 @@ const common_2 = require("@nestjs/common");
6
6
  const swagger_1 = require("@nestjs/swagger");
7
7
  const entity_response_decorator_1 = require("./entity-response.decorator");
8
8
  const validation_pipe_1 = require("../pipes/validation.pipe");
9
+ const handle_response_decorator_1 = require("./handle-response.decorator");
9
10
  const description = `Entity was updated successfully`;
10
11
  function Patch(UpdateDto, View) {
11
- return (0, common_1.applyDecorators)((0, common_2.Patch)(':id'), (0, swagger_1.ApiBody)({ type: UpdateDto }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(UpdateDto)));
12
+ return (0, common_1.applyDecorators)((0, common_2.Patch)(':id'), (0, swagger_1.ApiBody)({ type: UpdateDto }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(UpdateDto)), (0, handle_response_decorator_1.HandleResponse)());
12
13
  }
13
14
  //# sourceMappingURL=generic-patch.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generic-patch.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-patch.decorator.ts"],"names":[],"mappings":";;AASA,sBAWC;AApBD,2CAAuD;AACvD,2CAA8D;AAC9D,6CAAuD;AAEvD,2EAA6D;AAC7D,8DAAiE;AAEjE,MAAM,WAAW,GAAG,iCAAiC,CAAC;AAEtD,SAAgB,KAAK,CAAO,SAAkB,EAAE,IAAa;IAC3D,OAAO,IAAA,wBAAe,EACpB,IAAA,cAAS,EAAC,KAAK,CAAC,EAChB,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAC5B,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,SAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"generic-patch.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-patch.decorator.ts"],"names":[],"mappings":";;AAUA,sBAYC;AAtBD,2CAAuD;AACvD,2CAA8D;AAC9D,6CAAuD;AAEvD,2EAA6D;AAC7D,8DAAiE;AACjE,2EAA6D;AAE7D,MAAM,WAAW,GAAG,iCAAiC,CAAC;AAEtD,SAAgB,KAAK,CAAO,SAAkB,EAAE,IAAa;IAC3D,OAAO,IAAA,wBAAe,EACpB,IAAA,cAAS,EAAC,KAAK,CAAC,EAChB,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAC5B,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,SAAS,CAAC,CAAC,EAC1C,IAAA,0CAAc,GAAE,CACjB,CAAC;AACJ,CAAC"}
@@ -6,8 +6,9 @@ const common_2 = require("@nestjs/common");
6
6
  const swagger_1 = require("@nestjs/swagger");
7
7
  const entity_response_decorator_1 = require("./entity-response.decorator");
8
8
  const validation_pipe_1 = require("../pipes/validation.pipe");
9
+ const handle_response_decorator_1 = require("./handle-response.decorator");
9
10
  const description = `Entity was created successfully`;
10
11
  function Post(CreateDto, View) {
11
- return (0, common_1.applyDecorators)((0, common_2.Post)(), (0, swagger_1.ApiBody)({ type: CreateDto }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(CreateDto)));
12
+ return (0, common_1.applyDecorators)((0, common_2.Post)(), (0, swagger_1.ApiBody)({ type: CreateDto }), (0, entity_response_decorator_1.EntityResponse)(View, description), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, common_2.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(CreateDto)), (0, handle_response_decorator_1.HandleResponse)());
12
13
  }
13
14
  //# sourceMappingURL=generic-post.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generic-post.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-post.decorator.ts"],"names":[],"mappings":";;AASA,oBAUC;AAnBD,2CAAuD;AACvD,2CAA4D;AAC5D,6CAAuD;AAEvD,2EAA6D;AAC7D,8DAAiE;AAEjE,MAAM,WAAW,GAAG,iCAAiC,CAAC;AAEtD,SAAgB,IAAI,CAAO,SAAkB,EAAE,IAAa;IAC1D,OAAO,IAAA,wBAAe,EACpB,IAAA,aAAQ,GAAE,EACV,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAC5B,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,SAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"generic-post.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-post.decorator.ts"],"names":[],"mappings":";;AAUA,oBAWC;AArBD,2CAAuD;AACvD,2CAA4D;AAC5D,6CAAuD;AAEvD,2EAA6D;AAC7D,8DAAiE;AACjE,2EAA6D;AAE7D,MAAM,WAAW,GAAG,iCAAiC,CAAC;AAEtD,SAAgB,IAAI,CAAO,SAAkB,EAAE,IAAa;IAC1D,OAAO,IAAA,wBAAe,EACpB,IAAA,aAAQ,GAAE,EACV,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,EAC5B,IAAA,0CAAc,EAAC,IAAI,EAAE,WAAW,CAAC,EACjC,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,SAAS,CAAC,CAAC,EAC1C,IAAA,0CAAc,GAAE,CACjB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { Type } from '@nestjs/common';
2
+ import { IMapper } from '../interfaces/generic.mapper';
3
+ import { IExceptionMapper } from '../interfaces/exception-mapper';
4
+ import { Persistence } from '../../core/infra/generic.persistence';
5
+ import { Domain } from '../../core/domain/generic.domain';
6
+ import { View } from '../../core/app/dto/generic.view';
7
+ export declare function HandleResponse<M extends IMapper<T, D, V>, T extends Persistence = ReturnType<M['DomainToPersistence']>, D extends Domain = ReturnType<M['PersistenceToDomain']>, V extends View = ReturnType<M['DomainToView']>>(Handler?: Type<IExceptionMapper>): MethodDecorator;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HandleResponse = HandleResponse;
4
+ const response_handler_1 = require("../../core/app/response-handler");
5
+ const iroh_service_1 = require("../../core/iroh.service");
6
+ function HandleResponse(Handler) {
7
+ return function (target, propertyKey, descriptor) {
8
+ const { value: method } = descriptor;
9
+ descriptor.value = function (...args) {
10
+ const result = method.apply(this, args);
11
+ const controller = this;
12
+ const mapper = () => {
13
+ if (controller?.service instanceof iroh_service_1.Service) {
14
+ const EntityMapper = controller.service.mapper;
15
+ return EntityMapper.DomainToView;
16
+ }
17
+ return (x) => x;
18
+ };
19
+ const handler = () => {
20
+ if (Handler) {
21
+ return Handler.prototype.handle;
22
+ }
23
+ return null;
24
+ };
25
+ const params = { mapper: mapper(), handler: handler() };
26
+ if (result instanceof Promise) {
27
+ const promise = result;
28
+ return response_handler_1.ResponseHandler.async({ ...params, promise });
29
+ }
30
+ const data = result;
31
+ return response_handler_1.ResponseHandler.sync({ ...params, data });
32
+ };
33
+ return descriptor;
34
+ };
35
+ }
36
+ //# sourceMappingURL=handle-response.decorator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handle-response.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/handle-response.decorator.ts"],"names":[],"mappings":";;AAWA,wCA4CC;AArDD,sEAAkE;AAOlE,0DAAkD;AAElD,SAAgB,cAAc,CAK5B,OAAgC;IAChC,OAAO,UACL,MAAW,EACX,WAA4B,EAC5B,UAA8B;QAE9B,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC;QAErC,UAAU,CAAC,KAAK,GAAG,UAAU,GAAG,IAAW;YACzC,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACxC,MAAM,UAAU,GAAG,IAAW,CAAC;YAE/B,MAAM,MAAM,GAAG,GAAG,EAAE;gBAClB,IAAI,UAAU,EAAE,OAAO,YAAY,sBAAO,EAAE,CAAC;oBAC3C,MAAM,YAAY,GAAG,UAAU,CAAC,OAAO,CAAC,MAAW,CAAC;oBACpD,OAAO,YAAY,CAAC,YAAY,CAAC;gBACnC,CAAC;gBACD,OAAO,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC;YACvB,CAAC,CAAC;YAEF,MAAM,OAAO,GAAG,GAAG,EAAE;gBACnB,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC;gBAClC,CAAC;gBACD,OAAO,IAAI,CAAC;YACd,CAAC,CAAC;YAEF,MAAM,MAAM,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC;YAExD,IAAI,MAAM,YAAY,OAAO,EAAE,CAAC;gBAC9B,MAAM,OAAO,GAAG,MAA4B,CAAC;gBAC7C,OAAO,kCAAe,CAAC,KAAK,CAAC,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;YACvD,CAAC;YACD,MAAM,IAAI,GAAG,MAAmB,CAAC;YACjC,OAAO,kCAAe,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QACnD,CAAC,CAAC;QAEF,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC"}
@@ -8,6 +8,7 @@ export * from './generic-get-by-id.decorator';
8
8
  export * from './generic-get.decorator';
9
9
  export * from './generic-patch.decorator';
10
10
  export * from './generic-post.decorator';
11
+ export * from './handle-response.decorator';
11
12
  export * from './pagination.decorator';
12
13
  export * from './param.decorator';
13
14
  export * from './query-option.decorator';
@@ -24,6 +24,7 @@ __exportStar(require("./generic-get-by-id.decorator"), exports);
24
24
  __exportStar(require("./generic-get.decorator"), exports);
25
25
  __exportStar(require("./generic-patch.decorator"), exports);
26
26
  __exportStar(require("./generic-post.decorator"), exports);
27
+ __exportStar(require("./handle-response.decorator"), exports);
27
28
  __exportStar(require("./pagination.decorator"), exports);
28
29
  __exportStar(require("./param.decorator"), exports);
29
30
  __exportStar(require("./query-option.decorator"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,yDAAuC;AACvC,wDAAsC;AACtC,8DAA4C;AAC5C,qDAAmC;AACnC,6DAA2C;AAC3C,gEAA8C;AAC9C,0DAAwC;AACxC,4DAA0C;AAC1C,2DAAyC;AACzC,yDAAuC;AACvC,oDAAkC;AAClC,2DAAyC;AACzC,oDAAkC;AAClC,0DAAwC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,yDAAuC;AACvC,wDAAsC;AACtC,8DAA4C;AAC5C,qDAAmC;AACnC,6DAA2C;AAC3C,gEAA8C;AAC9C,0DAAwC;AACxC,4DAA0C;AAC1C,2DAAyC;AACzC,8DAA4C;AAC5C,yDAAuC;AACvC,oDAAkC;AAClC,2DAAyC;AACzC,oDAAkC;AAClC,0DAAwC"}
@@ -0,0 +1,5 @@
1
+ import { HttpException } from '@nestjs/common';
2
+ import { InternalServerErrorException as InternalServerError } from '@nestjs/common';
3
+ export interface IExceptionMapper {
4
+ handle<T extends HttpException = InternalServerError>(error: T): void;
5
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=exception-mapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exception-mapper.js","sourceRoot":"","sources":["../../../src/common/interfaces/exception-mapper.ts"],"names":[],"mappings":""}
@@ -1,6 +1,7 @@
1
1
  export * from './crud.controller';
2
2
  export * from './crud.repository';
3
3
  export * from './crud.service';
4
+ export * from './exception-mapper';
4
5
  export * from './generic.mapper';
5
6
  export * from './generic.props';
6
7
  export * from './nomenclator.props';
@@ -17,6 +17,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./crud.controller"), exports);
18
18
  __exportStar(require("./crud.repository"), exports);
19
19
  __exportStar(require("./crud.service"), exports);
20
+ __exportStar(require("./exception-mapper"), exports);
20
21
  __exportStar(require("./generic.mapper"), exports);
21
22
  __exportStar(require("./generic.props"), exports);
22
23
  __exportStar(require("./nomenclator.props"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,oDAAkC;AAClC,iDAA+B;AAC/B,mDAAiC;AACjC,kDAAgC;AAChC,sDAAoC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/interfaces/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,oDAAkC;AAClC,iDAA+B;AAC/B,qDAAmC;AACnC,mDAAiC;AACjC,kDAAgC;AAChC,sDAAoC"}
@@ -1,4 +1,5 @@
1
1
  import { Result } from './result';
2
+ import { Domain } from '../domain/generic.domain';
2
3
  export interface ResponseHandlerSyncParams<T> {
3
4
  data: Result<T>;
4
5
  mapper?: (res: any) => any;
@@ -10,7 +11,7 @@ export interface ResponseHandlerAsyncParams<T> {
10
11
  handler?: (res: any) => void;
11
12
  }
12
13
  export declare class ResponseHandler {
13
- static sync<T>({ data, mapper, handler, }: ResponseHandlerSyncParams<T>): any;
14
- static async<T>({ promise, mapper, handler, }: ResponseHandlerAsyncParams<T>): Promise<any>;
14
+ static sync<T, D extends Domain = Domain>(params: ResponseHandlerSyncParams<T>): any;
15
+ static async<T>(params: ResponseHandlerAsyncParams<T>): Promise<any>;
15
16
  private static handle;
16
17
  }
@@ -3,15 +3,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ResponseHandler = void 0;
4
4
  const defaultMapper = (a) => a;
5
5
  class ResponseHandler {
6
- static sync({ data, mapper, handler, }) {
6
+ static sync(params) {
7
+ const { data, mapper, handler } = params;
7
8
  const finalMapper = mapper || defaultMapper;
8
9
  if (!data.successful) {
9
10
  ResponseHandler.handle(data, handler);
10
11
  }
11
12
  const payload = data.unwrap();
13
+ const { pagination, items } = payload;
14
+ if (pagination && items) {
15
+ return { pagination, items: items.map((x) => finalMapper(x)) };
16
+ }
12
17
  return finalMapper(payload);
13
18
  }
14
- static async async({ promise, mapper, handler, }) {
19
+ static async async(params) {
20
+ const { promise, mapper, handler } = params;
15
21
  const data = await promise;
16
22
  if (!data.successful) {
17
23
  ResponseHandler.handle(data, handler);
@@ -1 +1 @@
1
- {"version":3,"file":"response-handler.js","sourceRoot":"","sources":["../../../src/core/app/response-handler.ts"],"names":[],"mappings":";;;AAEA,MAAM,aAAa,GAAG,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC;AAapC,MAAa,eAAe;IACnB,MAAM,CAAC,IAAI,CAAI,EACpB,IAAI,EACJ,MAAM,EACN,OAAO,GACsB;QAC7B,MAAM,WAAW,GAAG,MAAM,IAAI,aAAa,CAAC;QAE5C,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC9B,OAAO,WAAW,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,KAAK,CAAI,EAC3B,OAAO,EACP,MAAM,EACN,OAAO,GACuB;QAC9B,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,CAAI,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;IACjD,CAAC;IAEO,MAAM,CAAC,MAAM,CAAI,IAAe,EAAE,OAAY;QACpD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,KAAK,CAAC,CAAC;QACjB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;CACF;AArCD,0CAqCC"}
1
+ {"version":3,"file":"response-handler.js","sourceRoot":"","sources":["../../../src/core/app/response-handler.ts"],"names":[],"mappings":";;;AAIA,MAAM,aAAa,GAAG,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC;AAapC,MAAa,eAAe;IACnB,MAAM,CAAC,IAAI,CAChB,MAAoC;QAEpC,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;QACzC,MAAM,WAAW,GAAG,MAAM,IAAI,aAAa,CAAC;QAE5C,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC9B,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,OAAwB,CAAC;QACvD,IAAI,UAAU,IAAI,KAAK,EAAE,CAAC;YACxB,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACjE,CAAC;QACD,OAAO,WAAW,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,KAAK,CAAI,MAAqC;QAChE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;QAC5C,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,eAAe,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,CAAI,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;IACjD,CAAC;IAEO,MAAM,CAAC,MAAM,CAAI,IAAe,EAAE,OAAY;QACpD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,KAAK,CAAC,CAAC;QACjB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;CACF;AArCD,0CAqCC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rafikidota/iroh",
3
- "version": "0.46.0",
3
+ "version": "0.47.0",
4
4
  "description": "Sometimes, the best way to solve your own problems is to help someone else.",
5
5
  "repository": {
6
6
  "type": "git",
@@ -34,7 +34,7 @@
34
34
  "@angular-devkit/schematics": "19.2.13",
35
35
  "@angular-devkit/schematics-cli": "19.2.13",
36
36
  "@eslint/eslintrc": "3.3.1",
37
- "@eslint/js": "9.36.0",
37
+ "@eslint/js": "9.37.0",
38
38
  "@nestjs/common": "11.1.6",
39
39
  "@nestjs/config": "4.0.2",
40
40
  "@nestjs/core": "11.1.6",
@@ -45,13 +45,13 @@
45
45
  "@swc/core": "1.13.5",
46
46
  "@swc/helpers": "0.5.17",
47
47
  "@types/express": "5.0.3",
48
- "@types/node": "24.5.2",
48
+ "@types/node": "24.6.2",
49
49
  "@types/uuid": "11.0.0",
50
- "@typescript-eslint/eslint-plugin": "8.44.1",
51
- "@typescript-eslint/parser": "8.44.1",
50
+ "@typescript-eslint/eslint-plugin": "8.45.0",
51
+ "@typescript-eslint/parser": "8.45.0",
52
52
  "class-transformer": "0.5.1",
53
53
  "class-validator": "0.14.2",
54
- "eslint": "9.36.0",
54
+ "eslint": "9.37.0",
55
55
  "eslint-config-prettier": "10.1.8",
56
56
  "eslint-plugin-import": "2.32.0",
57
57
  "eslint-plugin-prettier": "5.5.4",
@@ -59,14 +59,14 @@
59
59
  "globals": "16.4.0",
60
60
  "husky": "9.1.7",
61
61
  "joi": "18.0.1",
62
- "lint-staged": "16.2.0",
62
+ "lint-staged": "16.2.3",
63
63
  "prettier": "3.6.2",
64
64
  "reflect-metadata": "0.2.2",
65
65
  "rimraf": "6.0.1",
66
66
  "rxjs": "7.8.2",
67
67
  "typeorm": "0.3.27",
68
- "typescript": "5.9.2",
69
- "typescript-eslint": "8.44.1",
68
+ "typescript": "5.9.3",
69
+ "typescript-eslint": "8.45.0",
70
70
  "uuid": "13.0.0"
71
71
  },
72
72
  "peerDependencies": {