@makebelieve21213-packages/nest-common 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.
Files changed (391) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +1905 -0
  3. package/dist/__tests__/index.spec.d.ts +2 -0
  4. package/dist/__tests__/index.spec.d.ts.map +1 -0
  5. package/dist/__tests__/index.spec.js +36 -0
  6. package/dist/__tests__/index.spec.js.map +1 -0
  7. package/dist/__tests__/mocks/logger-service.mock.d.ts +7 -0
  8. package/dist/__tests__/mocks/logger-service.mock.d.ts.map +1 -0
  9. package/dist/__tests__/mocks/logger-service.mock.js +16 -0
  10. package/dist/__tests__/mocks/logger-service.mock.js.map +1 -0
  11. package/dist/__tests__/setup.d.ts +2 -0
  12. package/dist/__tests__/setup.d.ts.map +1 -0
  13. package/dist/__tests__/setup.js +3 -0
  14. package/dist/__tests__/setup.js.map +1 -0
  15. package/dist/base/__tests__/base.controller.spec.d.ts +2 -0
  16. package/dist/base/__tests__/base.controller.spec.d.ts.map +1 -0
  17. package/dist/base/__tests__/base.controller.spec.js +50 -0
  18. package/dist/base/__tests__/base.controller.spec.js.map +1 -0
  19. package/dist/base/base.controller.d.ts +8 -0
  20. package/dist/base/base.controller.d.ts.map +1 -0
  21. package/dist/base/base.controller.js +15 -0
  22. package/dist/base/base.controller.js.map +1 -0
  23. package/dist/decorators/__tests__/api-key.decorator.spec.d.ts +2 -0
  24. package/dist/decorators/__tests__/api-key.decorator.spec.d.ts.map +1 -0
  25. package/dist/decorators/__tests__/api-key.decorator.spec.js +25 -0
  26. package/dist/decorators/__tests__/api-key.decorator.spec.js.map +1 -0
  27. package/dist/decorators/__tests__/permissions.decorator.spec.d.ts +2 -0
  28. package/dist/decorators/__tests__/permissions.decorator.spec.d.ts.map +1 -0
  29. package/dist/decorators/__tests__/permissions.decorator.spec.js +29 -0
  30. package/dist/decorators/__tests__/permissions.decorator.spec.js.map +1 -0
  31. package/dist/decorators/__tests__/public.decorator.spec.d.ts +2 -0
  32. package/dist/decorators/__tests__/public.decorator.spec.d.ts.map +1 -0
  33. package/dist/decorators/__tests__/public.decorator.spec.js +25 -0
  34. package/dist/decorators/__tests__/public.decorator.spec.js.map +1 -0
  35. package/dist/decorators/__tests__/roles.decorator.spec.d.ts +2 -0
  36. package/dist/decorators/__tests__/roles.decorator.spec.d.ts.map +1 -0
  37. package/dist/decorators/__tests__/roles.decorator.spec.js +29 -0
  38. package/dist/decorators/__tests__/roles.decorator.spec.js.map +1 -0
  39. package/dist/decorators/__tests__/serialize.decorator.spec.d.ts +2 -0
  40. package/dist/decorators/__tests__/serialize.decorator.spec.d.ts.map +1 -0
  41. package/dist/decorators/__tests__/serialize.decorator.spec.js +28 -0
  42. package/dist/decorators/__tests__/serialize.decorator.spec.js.map +1 -0
  43. package/dist/decorators/api-key.decorator.d.ts +3 -0
  44. package/dist/decorators/api-key.decorator.d.ts.map +1 -0
  45. package/dist/decorators/api-key.decorator.js +6 -0
  46. package/dist/decorators/api-key.decorator.js.map +1 -0
  47. package/dist/decorators/permissions.decorator.d.ts +3 -0
  48. package/dist/decorators/permissions.decorator.d.ts.map +1 -0
  49. package/dist/decorators/permissions.decorator.js +6 -0
  50. package/dist/decorators/permissions.decorator.js.map +1 -0
  51. package/dist/decorators/public.decorator.d.ts +3 -0
  52. package/dist/decorators/public.decorator.d.ts.map +1 -0
  53. package/dist/decorators/public.decorator.js +6 -0
  54. package/dist/decorators/public.decorator.js.map +1 -0
  55. package/dist/decorators/roles.decorator.d.ts +3 -0
  56. package/dist/decorators/roles.decorator.d.ts.map +1 -0
  57. package/dist/decorators/roles.decorator.js +6 -0
  58. package/dist/decorators/roles.decorator.js.map +1 -0
  59. package/dist/decorators/serialize.decorator.d.ts +3 -0
  60. package/dist/decorators/serialize.decorator.d.ts.map +1 -0
  61. package/dist/decorators/serialize.decorator.js +6 -0
  62. package/dist/decorators/serialize.decorator.js.map +1 -0
  63. package/dist/errors/__tests__/http.error.spec.d.ts +2 -0
  64. package/dist/errors/__tests__/http.error.spec.d.ts.map +1 -0
  65. package/dist/errors/__tests__/http.error.spec.js +667 -0
  66. package/dist/errors/__tests__/http.error.spec.js.map +1 -0
  67. package/dist/errors/__tests__/rpc.error.spec.d.ts +2 -0
  68. package/dist/errors/__tests__/rpc.error.spec.d.ts.map +1 -0
  69. package/dist/errors/__tests__/rpc.error.spec.js +336 -0
  70. package/dist/errors/__tests__/rpc.error.spec.js.map +1 -0
  71. package/dist/errors/__tests__/socket.error.spec.d.ts +2 -0
  72. package/dist/errors/__tests__/socket.error.spec.d.ts.map +1 -0
  73. package/dist/errors/__tests__/socket.error.spec.js +105 -0
  74. package/dist/errors/__tests__/socket.error.spec.js.map +1 -0
  75. package/dist/errors/http.error.d.ts +17 -0
  76. package/dist/errors/http.error.d.ts.map +1 -0
  77. package/dist/errors/http.error.js +170 -0
  78. package/dist/errors/http.error.js.map +1 -0
  79. package/dist/errors/nest-common.error.d.ts +7 -0
  80. package/dist/errors/nest-common.error.d.ts.map +1 -0
  81. package/dist/errors/nest-common.error.js +18 -0
  82. package/dist/errors/nest-common.error.js.map +1 -0
  83. package/dist/errors/rpc.error.d.ts +27 -0
  84. package/dist/errors/rpc.error.d.ts.map +1 -0
  85. package/dist/errors/rpc.error.js +170 -0
  86. package/dist/errors/rpc.error.js.map +1 -0
  87. package/dist/errors/socket.error.d.ts +20 -0
  88. package/dist/errors/socket.error.d.ts.map +1 -0
  89. package/dist/errors/socket.error.js +47 -0
  90. package/dist/errors/socket.error.js.map +1 -0
  91. package/dist/filters/__tests__/http-exception-handler.spec.d.ts +2 -0
  92. package/dist/filters/__tests__/http-exception-handler.spec.d.ts.map +1 -0
  93. package/dist/filters/__tests__/http-exception-handler.spec.js +86 -0
  94. package/dist/filters/__tests__/http-exception-handler.spec.js.map +1 -0
  95. package/dist/filters/__tests__/rpc-exception-handler.spec.d.ts +2 -0
  96. package/dist/filters/__tests__/rpc-exception-handler.spec.d.ts.map +1 -0
  97. package/dist/filters/__tests__/rpc-exception-handler.spec.js +220 -0
  98. package/dist/filters/__tests__/rpc-exception-handler.spec.js.map +1 -0
  99. package/dist/filters/__tests__/unified-exception.filter.spec.d.ts +2 -0
  100. package/dist/filters/__tests__/unified-exception.filter.spec.d.ts.map +1 -0
  101. package/dist/filters/__tests__/unified-exception.filter.spec.js +233 -0
  102. package/dist/filters/__tests__/unified-exception.filter.spec.js.map +1 -0
  103. package/dist/filters/__tests__/websocket-exception-handler.spec.d.ts +2 -0
  104. package/dist/filters/__tests__/websocket-exception-handler.spec.d.ts.map +1 -0
  105. package/dist/filters/__tests__/websocket-exception-handler.spec.js +78 -0
  106. package/dist/filters/__tests__/websocket-exception-handler.spec.js.map +1 -0
  107. package/dist/filters/http-exception-handler.d.ts +8 -0
  108. package/dist/filters/http-exception-handler.d.ts.map +1 -0
  109. package/dist/filters/http-exception-handler.js +37 -0
  110. package/dist/filters/http-exception-handler.js.map +1 -0
  111. package/dist/filters/rpc-exception-handler.d.ts +11 -0
  112. package/dist/filters/rpc-exception-handler.d.ts.map +1 -0
  113. package/dist/filters/rpc-exception-handler.js +87 -0
  114. package/dist/filters/rpc-exception-handler.js.map +1 -0
  115. package/dist/filters/unified-exception.filter.d.ts +12 -0
  116. package/dist/filters/unified-exception.filter.d.ts.map +1 -0
  117. package/dist/filters/unified-exception.filter.js +63 -0
  118. package/dist/filters/unified-exception.filter.js.map +1 -0
  119. package/dist/filters/websocket-exception-handler.d.ts +8 -0
  120. package/dist/filters/websocket-exception-handler.d.ts.map +1 -0
  121. package/dist/filters/websocket-exception-handler.js +47 -0
  122. package/dist/filters/websocket-exception-handler.js.map +1 -0
  123. package/dist/guards/__tests__/api-key.guard.spec.d.ts +2 -0
  124. package/dist/guards/__tests__/api-key.guard.spec.d.ts.map +1 -0
  125. package/dist/guards/__tests__/api-key.guard.spec.js +123 -0
  126. package/dist/guards/__tests__/api-key.guard.spec.js.map +1 -0
  127. package/dist/guards/__tests__/jwt-auth.guard.spec.d.ts +2 -0
  128. package/dist/guards/__tests__/jwt-auth.guard.spec.d.ts.map +1 -0
  129. package/dist/guards/__tests__/jwt-auth.guard.spec.js +61 -0
  130. package/dist/guards/__tests__/jwt-auth.guard.spec.js.map +1 -0
  131. package/dist/guards/__tests__/permissions.guard.spec.d.ts +2 -0
  132. package/dist/guards/__tests__/permissions.guard.spec.d.ts.map +1 -0
  133. package/dist/guards/__tests__/permissions.guard.spec.js +77 -0
  134. package/dist/guards/__tests__/permissions.guard.spec.js.map +1 -0
  135. package/dist/guards/__tests__/rate-limit.guard.spec.d.ts +2 -0
  136. package/dist/guards/__tests__/rate-limit.guard.spec.d.ts.map +1 -0
  137. package/dist/guards/__tests__/rate-limit.guard.spec.js +117 -0
  138. package/dist/guards/__tests__/rate-limit.guard.spec.js.map +1 -0
  139. package/dist/guards/__tests__/roles.guard.spec.d.ts +2 -0
  140. package/dist/guards/__tests__/roles.guard.spec.d.ts.map +1 -0
  141. package/dist/guards/__tests__/roles.guard.spec.js +83 -0
  142. package/dist/guards/__tests__/roles.guard.spec.js.map +1 -0
  143. package/dist/guards/__tests__/websocket-auth.guard.spec.d.ts +2 -0
  144. package/dist/guards/__tests__/websocket-auth.guard.spec.d.ts.map +1 -0
  145. package/dist/guards/__tests__/websocket-auth.guard.spec.js +72 -0
  146. package/dist/guards/__tests__/websocket-auth.guard.spec.js.map +1 -0
  147. package/dist/guards/api-key.guard.d.ts +10 -0
  148. package/dist/guards/api-key.guard.d.ts.map +1 -0
  149. package/dist/guards/api-key.guard.js +58 -0
  150. package/dist/guards/api-key.guard.js.map +1 -0
  151. package/dist/guards/jwt-auth.guard.d.ts +8 -0
  152. package/dist/guards/jwt-auth.guard.d.ts.map +1 -0
  153. package/dist/guards/jwt-auth.guard.js +41 -0
  154. package/dist/guards/jwt-auth.guard.js.map +1 -0
  155. package/dist/guards/permissions.guard.d.ts +8 -0
  156. package/dist/guards/permissions.guard.d.ts.map +1 -0
  157. package/dist/guards/permissions.guard.js +48 -0
  158. package/dist/guards/permissions.guard.js.map +1 -0
  159. package/dist/guards/rate-limit.guard.d.ts +16 -0
  160. package/dist/guards/rate-limit.guard.d.ts.map +1 -0
  161. package/dist/guards/rate-limit.guard.js +89 -0
  162. package/dist/guards/rate-limit.guard.js.map +1 -0
  163. package/dist/guards/roles.guard.d.ts +8 -0
  164. package/dist/guards/roles.guard.d.ts.map +1 -0
  165. package/dist/guards/roles.guard.js +48 -0
  166. package/dist/guards/roles.guard.js.map +1 -0
  167. package/dist/guards/websocket-auth.guard.d.ts +8 -0
  168. package/dist/guards/websocket-auth.guard.d.ts.map +1 -0
  169. package/dist/guards/websocket-auth.guard.js +41 -0
  170. package/dist/guards/websocket-auth.guard.js.map +1 -0
  171. package/dist/index.d.ts +46 -0
  172. package/dist/index.d.ts.map +1 -0
  173. package/dist/index.js +38 -0
  174. package/dist/index.js.map +1 -0
  175. package/dist/interceptors/__tests__/compression.interceptor.spec.d.ts +2 -0
  176. package/dist/interceptors/__tests__/compression.interceptor.spec.d.ts.map +1 -0
  177. package/dist/interceptors/__tests__/compression.interceptor.spec.js +93 -0
  178. package/dist/interceptors/__tests__/compression.interceptor.spec.js.map +1 -0
  179. package/dist/interceptors/__tests__/http-logging.interceptor.spec.d.ts +2 -0
  180. package/dist/interceptors/__tests__/http-logging.interceptor.spec.d.ts.map +1 -0
  181. package/dist/interceptors/__tests__/http-logging.interceptor.spec.js +135 -0
  182. package/dist/interceptors/__tests__/http-logging.interceptor.spec.js.map +1 -0
  183. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.d.ts +2 -0
  184. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.d.ts.map +1 -0
  185. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.js +39 -0
  186. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.js.map +1 -0
  187. package/dist/interceptors/__tests__/response.interceptor.spec.d.ts +2 -0
  188. package/dist/interceptors/__tests__/response.interceptor.spec.d.ts.map +1 -0
  189. package/dist/interceptors/__tests__/response.interceptor.spec.js +95 -0
  190. package/dist/interceptors/__tests__/response.interceptor.spec.js.map +1 -0
  191. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.d.ts +2 -0
  192. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.d.ts.map +1 -0
  193. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.js +113 -0
  194. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.js.map +1 -0
  195. package/dist/interceptors/__tests__/serialize.interceptor.spec.d.ts +2 -0
  196. package/dist/interceptors/__tests__/serialize.interceptor.spec.d.ts.map +1 -0
  197. package/dist/interceptors/__tests__/serialize.interceptor.spec.js +114 -0
  198. package/dist/interceptors/__tests__/serialize.interceptor.spec.js.map +1 -0
  199. package/dist/interceptors/__tests__/unified.interceptor.spec.d.ts +2 -0
  200. package/dist/interceptors/__tests__/unified.interceptor.spec.d.ts.map +1 -0
  201. package/dist/interceptors/__tests__/unified.interceptor.spec.js +256 -0
  202. package/dist/interceptors/__tests__/unified.interceptor.spec.js.map +1 -0
  203. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.d.ts +2 -0
  204. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.d.ts.map +1 -0
  205. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.js +119 -0
  206. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.js.map +1 -0
  207. package/dist/interceptors/compression.interceptor.d.ts +10 -0
  208. package/dist/interceptors/compression.interceptor.d.ts.map +1 -0
  209. package/dist/interceptors/compression.interceptor.js +53 -0
  210. package/dist/interceptors/compression.interceptor.js.map +1 -0
  211. package/dist/interceptors/http-logging.interceptor.d.ts +9 -0
  212. package/dist/interceptors/http-logging.interceptor.d.ts.map +1 -0
  213. package/dist/interceptors/http-logging.interceptor.js +41 -0
  214. package/dist/interceptors/http-logging.interceptor.js.map +1 -0
  215. package/dist/interceptors/request-id-response.interceptor.d.ts +6 -0
  216. package/dist/interceptors/request-id-response.interceptor.d.ts.map +1 -0
  217. package/dist/interceptors/request-id-response.interceptor.js +27 -0
  218. package/dist/interceptors/request-id-response.interceptor.js.map +1 -0
  219. package/dist/interceptors/response.interceptor.d.ts +8 -0
  220. package/dist/interceptors/response.interceptor.d.ts.map +1 -0
  221. package/dist/interceptors/response.interceptor.js +42 -0
  222. package/dist/interceptors/response.interceptor.js.map +1 -0
  223. package/dist/interceptors/rpc-logging.interceptor.d.ts +9 -0
  224. package/dist/interceptors/rpc-logging.interceptor.d.ts.map +1 -0
  225. package/dist/interceptors/rpc-logging.interceptor.js +31 -0
  226. package/dist/interceptors/rpc-logging.interceptor.js.map +1 -0
  227. package/dist/interceptors/serialize.interceptor.d.ts +9 -0
  228. package/dist/interceptors/serialize.interceptor.d.ts.map +1 -0
  229. package/dist/interceptors/serialize.interceptor.js +48 -0
  230. package/dist/interceptors/serialize.interceptor.js.map +1 -0
  231. package/dist/interceptors/unified.interceptor.d.ts +12 -0
  232. package/dist/interceptors/unified.interceptor.d.ts.map +1 -0
  233. package/dist/interceptors/unified.interceptor.js +54 -0
  234. package/dist/interceptors/unified.interceptor.js.map +1 -0
  235. package/dist/interceptors/websocket-logging.interceptor.d.ts +9 -0
  236. package/dist/interceptors/websocket-logging.interceptor.d.ts.map +1 -0
  237. package/dist/interceptors/websocket-logging.interceptor.js +36 -0
  238. package/dist/interceptors/websocket-logging.interceptor.js.map +1 -0
  239. package/dist/pipes/__tests__/file-validation.pipe.spec.d.ts +2 -0
  240. package/dist/pipes/__tests__/file-validation.pipe.spec.d.ts.map +1 -0
  241. package/dist/pipes/__tests__/file-validation.pipe.spec.js +60 -0
  242. package/dist/pipes/__tests__/file-validation.pipe.spec.js.map +1 -0
  243. package/dist/pipes/__tests__/header-validation.pipe.spec.d.ts +2 -0
  244. package/dist/pipes/__tests__/header-validation.pipe.spec.d.ts.map +1 -0
  245. package/dist/pipes/__tests__/header-validation.pipe.spec.js +111 -0
  246. package/dist/pipes/__tests__/header-validation.pipe.spec.js.map +1 -0
  247. package/dist/pipes/__tests__/http-validation.pipe.spec.d.ts +2 -0
  248. package/dist/pipes/__tests__/http-validation.pipe.spec.d.ts.map +1 -0
  249. package/dist/pipes/__tests__/http-validation.pipe.spec.js +114 -0
  250. package/dist/pipes/__tests__/http-validation.pipe.spec.js.map +1 -0
  251. package/dist/pipes/__tests__/query-validation.pipe.spec.d.ts +2 -0
  252. package/dist/pipes/__tests__/query-validation.pipe.spec.d.ts.map +1 -0
  253. package/dist/pipes/__tests__/query-validation.pipe.spec.js +103 -0
  254. package/dist/pipes/__tests__/query-validation.pipe.spec.js.map +1 -0
  255. package/dist/pipes/__tests__/rpc-validation.pipe.spec.d.ts +2 -0
  256. package/dist/pipes/__tests__/rpc-validation.pipe.spec.d.ts.map +1 -0
  257. package/dist/pipes/__tests__/rpc-validation.pipe.spec.js +126 -0
  258. package/dist/pipes/__tests__/rpc-validation.pipe.spec.js.map +1 -0
  259. package/dist/pipes/file-validation.pipe.d.ts +10 -0
  260. package/dist/pipes/file-validation.pipe.d.ts.map +1 -0
  261. package/dist/pipes/file-validation.pipe.js +41 -0
  262. package/dist/pipes/file-validation.pipe.js.map +1 -0
  263. package/dist/pipes/header-validation.pipe.d.ts +8 -0
  264. package/dist/pipes/header-validation.pipe.d.ts.map +1 -0
  265. package/dist/pipes/header-validation.pipe.js +58 -0
  266. package/dist/pipes/header-validation.pipe.js.map +1 -0
  267. package/dist/pipes/http-validation.pipe.d.ts +8 -0
  268. package/dist/pipes/http-validation.pipe.d.ts.map +1 -0
  269. package/dist/pipes/http-validation.pipe.js +41 -0
  270. package/dist/pipes/http-validation.pipe.js.map +1 -0
  271. package/dist/pipes/query-validation.pipe.d.ts +8 -0
  272. package/dist/pipes/query-validation.pipe.d.ts.map +1 -0
  273. package/dist/pipes/query-validation.pipe.js +58 -0
  274. package/dist/pipes/query-validation.pipe.js.map +1 -0
  275. package/dist/pipes/rpc-validation.pipe.d.ts +8 -0
  276. package/dist/pipes/rpc-validation.pipe.d.ts.map +1 -0
  277. package/dist/pipes/rpc-validation.pipe.js +49 -0
  278. package/dist/pipes/rpc-validation.pipe.js.map +1 -0
  279. package/dist/types/circuit-breaker-types.d.ts +19 -0
  280. package/dist/types/circuit-breaker-types.d.ts.map +1 -0
  281. package/dist/types/circuit-breaker-types.js +8 -0
  282. package/dist/types/circuit-breaker-types.js.map +1 -0
  283. package/dist/types/compression-types.d.ts +22 -0
  284. package/dist/types/compression-types.d.ts.map +1 -0
  285. package/dist/types/compression-types.js +2 -0
  286. package/dist/types/compression-types.js.map +1 -0
  287. package/dist/types/context-types.d.ts +18 -0
  288. package/dist/types/context-types.d.ts.map +1 -0
  289. package/dist/types/context-types.js +8 -0
  290. package/dist/types/context-types.js.map +1 -0
  291. package/dist/types/cors-types.d.ts +11 -0
  292. package/dist/types/cors-types.d.ts.map +1 -0
  293. package/dist/types/cors-types.js +2 -0
  294. package/dist/types/cors-types.js.map +1 -0
  295. package/dist/types/error-types.d.ts +13 -0
  296. package/dist/types/error-types.d.ts.map +1 -0
  297. package/dist/types/error-types.js +15 -0
  298. package/dist/types/error-types.js.map +1 -0
  299. package/dist/types/file-types.d.ts +13 -0
  300. package/dist/types/file-types.d.ts.map +1 -0
  301. package/dist/types/file-types.js +2 -0
  302. package/dist/types/file-types.js.map +1 -0
  303. package/dist/types/file-validation-types.d.ts +10 -0
  304. package/dist/types/file-validation-types.d.ts.map +1 -0
  305. package/dist/types/file-validation-types.js +2 -0
  306. package/dist/types/file-validation-types.js.map +1 -0
  307. package/dist/types/get-service-path-types.d.ts +16 -0
  308. package/dist/types/get-service-path-types.d.ts.map +1 -0
  309. package/dist/types/get-service-path-types.js +2 -0
  310. package/dist/types/get-service-path-types.js.map +1 -0
  311. package/dist/types/guard-types.d.ts +5 -0
  312. package/dist/types/guard-types.d.ts.map +1 -0
  313. package/dist/types/guard-types.js +2 -0
  314. package/dist/types/guard-types.js.map +1 -0
  315. package/dist/types/http-response.d.ts +19 -0
  316. package/dist/types/http-response.d.ts.map +1 -0
  317. package/dist/types/http-response.js +2 -0
  318. package/dist/types/http-response.js.map +1 -0
  319. package/dist/types/rpc-types.d.ts +21 -0
  320. package/dist/types/rpc-types.d.ts.map +1 -0
  321. package/dist/types/rpc-types.js +17 -0
  322. package/dist/types/rpc-types.js.map +1 -0
  323. package/dist/types/versioning-types.d.ts +8 -0
  324. package/dist/types/versioning-types.d.ts.map +1 -0
  325. package/dist/types/versioning-types.js +2 -0
  326. package/dist/types/versioning-types.js.map +1 -0
  327. package/dist/utils/__tests__/circuit-breaker.spec.d.ts +2 -0
  328. package/dist/utils/__tests__/circuit-breaker.spec.d.ts.map +1 -0
  329. package/dist/utils/__tests__/circuit-breaker.spec.js +206 -0
  330. package/dist/utils/__tests__/circuit-breaker.spec.js.map +1 -0
  331. package/dist/utils/__tests__/compression.utils.spec.d.ts +2 -0
  332. package/dist/utils/__tests__/compression.utils.spec.d.ts.map +1 -0
  333. package/dist/utils/__tests__/compression.utils.spec.js +106 -0
  334. package/dist/utils/__tests__/compression.utils.spec.js.map +1 -0
  335. package/dist/utils/__tests__/context.utils.spec.d.ts +2 -0
  336. package/dist/utils/__tests__/context.utils.spec.d.ts.map +1 -0
  337. package/dist/utils/__tests__/context.utils.spec.js +112 -0
  338. package/dist/utils/__tests__/context.utils.spec.js.map +1 -0
  339. package/dist/utils/__tests__/cors.utils.spec.d.ts +2 -0
  340. package/dist/utils/__tests__/cors.utils.spec.d.ts.map +1 -0
  341. package/dist/utils/__tests__/cors.utils.spec.js +54 -0
  342. package/dist/utils/__tests__/cors.utils.spec.js.map +1 -0
  343. package/dist/utils/__tests__/env-validator.spec.d.ts +2 -0
  344. package/dist/utils/__tests__/env-validator.spec.d.ts.map +1 -0
  345. package/dist/utils/__tests__/env-validator.spec.js +88 -0
  346. package/dist/utils/__tests__/env-validator.spec.js.map +1 -0
  347. package/dist/utils/__tests__/file.utils.spec.d.ts +2 -0
  348. package/dist/utils/__tests__/file.utils.spec.d.ts.map +1 -0
  349. package/dist/utils/__tests__/file.utils.spec.js +95 -0
  350. package/dist/utils/__tests__/file.utils.spec.js.map +1 -0
  351. package/dist/utils/__tests__/get-service-path.spec.d.ts +2 -0
  352. package/dist/utils/__tests__/get-service-path.spec.d.ts.map +1 -0
  353. package/dist/utils/__tests__/get-service-path.spec.js +385 -0
  354. package/dist/utils/__tests__/get-service-path.spec.js.map +1 -0
  355. package/dist/utils/__tests__/versioning.utils.spec.d.ts +2 -0
  356. package/dist/utils/__tests__/versioning.utils.spec.d.ts.map +1 -0
  357. package/dist/utils/__tests__/versioning.utils.spec.js +66 -0
  358. package/dist/utils/__tests__/versioning.utils.spec.js.map +1 -0
  359. package/dist/utils/circuit-breaker.d.ts +15 -0
  360. package/dist/utils/circuit-breaker.d.ts.map +1 -0
  361. package/dist/utils/circuit-breaker.js +96 -0
  362. package/dist/utils/circuit-breaker.js.map +1 -0
  363. package/dist/utils/compression.utils.d.ts +3 -0
  364. package/dist/utils/compression.utils.d.ts.map +1 -0
  365. package/dist/utils/compression.utils.js +25 -0
  366. package/dist/utils/compression.utils.js.map +1 -0
  367. package/dist/utils/context.utils.d.ts +7 -0
  368. package/dist/utils/context.utils.d.ts.map +1 -0
  369. package/dist/utils/context.utils.js +24 -0
  370. package/dist/utils/context.utils.js.map +1 -0
  371. package/dist/utils/cors.utils.d.ts +4 -0
  372. package/dist/utils/cors.utils.d.ts.map +1 -0
  373. package/dist/utils/cors.utils.js +23 -0
  374. package/dist/utils/cors.utils.js.map +1 -0
  375. package/dist/utils/env-validator.d.ts +2 -0
  376. package/dist/utils/env-validator.d.ts.map +1 -0
  377. package/dist/utils/env-validator.js +22 -0
  378. package/dist/utils/env-validator.js.map +1 -0
  379. package/dist/utils/file.utils.d.ts +6 -0
  380. package/dist/utils/file.utils.d.ts.map +1 -0
  381. package/dist/utils/file.utils.js +42 -0
  382. package/dist/utils/file.utils.js.map +1 -0
  383. package/dist/utils/get-service-path.d.ts +9 -0
  384. package/dist/utils/get-service-path.d.ts.map +1 -0
  385. package/dist/utils/get-service-path.js +65 -0
  386. package/dist/utils/get-service-path.js.map +1 -0
  387. package/dist/utils/versioning.utils.d.ts +4 -0
  388. package/dist/utils/versioning.utils.d.ts.map +1 -0
  389. package/dist/utils/versioning.utils.js +30 -0
  390. package/dist/utils/versioning.utils.js.map +1 -0
  391. package/package.json +95 -0
@@ -0,0 +1,256 @@
1
+ import { HttpStatus } from "@nestjs/common";
2
+ import { of, throwError } from "rxjs";
3
+ import { createLoggerServiceMock } from "../../__tests__/mocks/logger-service.mock.js";
4
+ import HttpLoggingInterceptor from "../../interceptors/http-logging.interceptor.js";
5
+ import RpcLoggingInterceptor from "../../interceptors/rpc-logging.interceptor.js";
6
+ import UnifiedInterceptor from "../../interceptors/unified.interceptor.js";
7
+ import WebSocketLoggingInterceptor from "../../interceptors/websocket-logging.interceptor.js";
8
+ import { ContextType } from "../../types/context-types.js";
9
+ describe("UnifiedInterceptor", () => {
10
+ let interceptor;
11
+ let loggerService;
12
+ let executionContext;
13
+ let callHandler;
14
+ let mockRequest;
15
+ let mockResponse;
16
+ beforeEach(() => {
17
+ loggerService = createLoggerServiceMock();
18
+ interceptor = new UnifiedInterceptor(loggerService);
19
+ mockRequest = {
20
+ method: "GET",
21
+ url: "/api/test",
22
+ originalUrl: "/api/test",
23
+ ip: "127.0.0.1",
24
+ socket: {
25
+ remoteAddress: "127.0.0.1",
26
+ },
27
+ get: jest.fn().mockReturnValue("test-user-agent"),
28
+ };
29
+ mockResponse = {
30
+ statusCode: HttpStatus.OK,
31
+ };
32
+ executionContext = {
33
+ getType: jest.fn(),
34
+ switchToHttp: jest.fn(),
35
+ switchToRpc: jest.fn(),
36
+ switchToWs: jest.fn(),
37
+ };
38
+ callHandler = {
39
+ handle: jest.fn(),
40
+ };
41
+ });
42
+ describe("конструктор", () => {
43
+ it("должен установить контекст логгера", () => {
44
+ expect(loggerService.setContext).toHaveBeenCalledWith("UnifiedInterceptor");
45
+ });
46
+ it("должен создать обработчики HTTP, RPC и WebSocket", () => {
47
+ expect(interceptor).toBeInstanceOf(UnifiedInterceptor);
48
+ });
49
+ it("должен создать HttpLoggingInterceptor с моком логгера для покрытия строки параметра конструктора", () => {
50
+ // Явно создаем HttpLoggingInterceptor с моком логгера
51
+ // для покрытия строки параметра конструктора
52
+ const httpHandler = new HttpLoggingInterceptor(loggerService);
53
+ expect(httpHandler).toBeInstanceOf(HttpLoggingInterceptor);
54
+ });
55
+ it("должен создать RpcLoggingInterceptor с моком логгера для покрытия строки параметра конструктора", () => {
56
+ // Явно создаем RpcLoggingInterceptor с моком логгера
57
+ // для покрытия строки параметра конструктора
58
+ const rpcHandler = new RpcLoggingInterceptor(loggerService);
59
+ expect(rpcHandler).toBeInstanceOf(RpcLoggingInterceptor);
60
+ });
61
+ it("должен создать WebSocketLoggingInterceptor с моком логгера для покрытия строки параметра конструктора", () => {
62
+ // Явно создаем WebSocketLoggingInterceptor с моком логгера
63
+ // для покрытия строки параметра конструктора
64
+ const wsHandler = new WebSocketLoggingInterceptor(loggerService);
65
+ expect(wsHandler).toBeInstanceOf(WebSocketLoggingInterceptor);
66
+ });
67
+ it("должен покрыть строку 20 - параметр loggerService конструктора UnifiedInterceptor", () => {
68
+ // Явно создаем экземпляр с моком логгера для покрытия параметра конструктора
69
+ const testLoggerService = createLoggerServiceMock();
70
+ const testInterceptor = new UnifiedInterceptor(testLoggerService);
71
+ expect(testInterceptor).toBeInstanceOf(UnifiedInterceptor);
72
+ // Вызываем метод, чтобы убедиться, что мок используется
73
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.HTTP);
74
+ executionContext.switchToHttp = jest.fn().mockReturnValue({
75
+ getRequest: jest.fn().mockReturnValue(mockRequest),
76
+ getResponse: jest.fn().mockReturnValue(mockResponse),
77
+ });
78
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
79
+ testInterceptor.intercept(executionContext, callHandler);
80
+ expect(testLoggerService.setContext).toHaveBeenCalled();
81
+ });
82
+ it("должен покрыть строку 22 - параметр loggerService конструктора UnifiedInterceptor", () => {
83
+ // Покрываем строку 22 - параметр loggerService конструктора
84
+ const testLoggerService = createLoggerServiceMock();
85
+ const testInterceptor = new UnifiedInterceptor(testLoggerService);
86
+ expect(testInterceptor).toBeInstanceOf(UnifiedInterceptor);
87
+ // Вызываем метод для разных контекстов, чтобы убедиться, что мок используется
88
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.RPC);
89
+ const rmqContext = {
90
+ getChannelRef: jest.fn(),
91
+ getMessage: jest.fn(),
92
+ getPattern: jest.fn().mockReturnValue("test.pattern"),
93
+ };
94
+ executionContext.switchToRpc = jest.fn().mockReturnValue({
95
+ getContext: jest.fn().mockReturnValue(rmqContext),
96
+ });
97
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
98
+ testInterceptor.intercept(executionContext, callHandler);
99
+ expect(testLoggerService.setContext).toHaveBeenCalled();
100
+ });
101
+ it("должен покрыть все ветки конструктора для разных контекстов", () => {
102
+ const testLoggerService = createLoggerServiceMock();
103
+ const testInterceptor = new UnifiedInterceptor(testLoggerService);
104
+ expect(testInterceptor).toBeInstanceOf(UnifiedInterceptor);
105
+ // Тестируем все типы контекстов для покрытия всех веток
106
+ // HTTP контекст
107
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.HTTP);
108
+ executionContext.switchToHttp = jest.fn().mockReturnValue({
109
+ getRequest: jest.fn().mockReturnValue(mockRequest),
110
+ getResponse: jest.fn().mockReturnValue(mockResponse),
111
+ });
112
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
113
+ testInterceptor.intercept(executionContext, callHandler);
114
+ // WebSocket контекст
115
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.WS);
116
+ executionContext.switchToWs = jest.fn().mockReturnValue({
117
+ getClient: jest.fn().mockReturnValue({ id: "test-client" }),
118
+ getData: jest.fn().mockReturnValue({ test: "data" }),
119
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
120
+ });
121
+ testInterceptor.intercept(executionContext, callHandler);
122
+ // Неизвестный контекст
123
+ executionContext.getType = jest.fn().mockReturnValue("unknown");
124
+ testInterceptor.intercept(executionContext, callHandler);
125
+ expect(testLoggerService.setContext).toHaveBeenCalled();
126
+ });
127
+ });
128
+ describe("intercept", () => {
129
+ it("должен обработать HTTP контекст", (done) => {
130
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.HTTP);
131
+ executionContext.switchToHttp = jest.fn().mockReturnValue({
132
+ getRequest: jest.fn().mockReturnValue(mockRequest),
133
+ getResponse: jest.fn().mockReturnValue(mockResponse),
134
+ });
135
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
136
+ const result = interceptor.intercept(executionContext, callHandler);
137
+ result.subscribe({
138
+ next: (value) => {
139
+ expect(value).toEqual({ result: "success" });
140
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[HTTP] Incoming request"));
141
+ done();
142
+ },
143
+ });
144
+ });
145
+ it("должен обработать RPC контекст", (done) => {
146
+ const pattern = "test.pattern";
147
+ const rmqContext = {
148
+ getChannelRef: jest.fn(),
149
+ getMessage: jest.fn(),
150
+ getPattern: jest.fn().mockReturnValue(pattern),
151
+ };
152
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.RPC);
153
+ executionContext.switchToRpc = jest.fn().mockReturnValue({
154
+ getContext: jest.fn().mockReturnValue(rmqContext),
155
+ });
156
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
157
+ const result = interceptor.intercept(executionContext, callHandler);
158
+ result.subscribe({
159
+ next: (value) => {
160
+ expect(value).toEqual({ result: "success" });
161
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[RPC] Incoming request"));
162
+ done();
163
+ },
164
+ });
165
+ });
166
+ it("должен обработать WebSocket контекст", (done) => {
167
+ const mockClient = { id: "test-client-id" };
168
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.WS);
169
+ executionContext.switchToWs = jest.fn().mockReturnValue({
170
+ getClient: jest.fn().mockReturnValue(mockClient),
171
+ getData: jest.fn().mockReturnValue({ test: "data" }),
172
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
173
+ });
174
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
175
+ const result = interceptor.intercept(executionContext, callHandler);
176
+ result.subscribe({
177
+ next: (value) => {
178
+ expect(value).toEqual({ result: "success" });
179
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[WS] Incoming event"));
180
+ done();
181
+ },
182
+ });
183
+ });
184
+ it("должен пропустить запрос для неизвестного контекста", () => {
185
+ executionContext.getType = jest.fn().mockReturnValue("unknown");
186
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
187
+ const result = interceptor.intercept(executionContext, callHandler);
188
+ result.subscribe({
189
+ next: (value) => {
190
+ expect(value).toEqual({ result: "success" });
191
+ expect(callHandler.handle).toHaveBeenCalled();
192
+ },
193
+ });
194
+ });
195
+ it("должен обработать ошибку в HTTP контексте", (done) => {
196
+ const error = new Error("Test error");
197
+ mockResponse.statusCode = HttpStatus.INTERNAL_SERVER_ERROR;
198
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.HTTP);
199
+ executionContext.switchToHttp = jest.fn().mockReturnValue({
200
+ getRequest: jest.fn().mockReturnValue(mockRequest),
201
+ getResponse: jest.fn().mockReturnValue(mockResponse),
202
+ });
203
+ callHandler.handle.mockReturnValue(throwError(() => error));
204
+ const result = interceptor.intercept(executionContext, callHandler);
205
+ result.subscribe({
206
+ error: (err) => {
207
+ expect(err).toBe(error);
208
+ expect(loggerService.error).toHaveBeenCalledWith(expect.stringContaining("[HTTP] Request failed"));
209
+ done();
210
+ },
211
+ });
212
+ });
213
+ it("должен обработать ошибку в RPC контексте", (done) => {
214
+ const pattern = "test.pattern";
215
+ const rmqContext = {
216
+ getChannelRef: jest.fn(),
217
+ getMessage: jest.fn(),
218
+ getPattern: jest.fn().mockReturnValue(pattern),
219
+ };
220
+ const error = new Error("Test error");
221
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.RPC);
222
+ executionContext.switchToRpc = jest.fn().mockReturnValue({
223
+ getContext: jest.fn().mockReturnValue(rmqContext),
224
+ });
225
+ callHandler.handle.mockReturnValue(throwError(() => error));
226
+ const result = interceptor.intercept(executionContext, callHandler);
227
+ result.subscribe({
228
+ error: (err) => {
229
+ expect(err).toBe(error);
230
+ expect(loggerService.error).toHaveBeenCalledWith(expect.stringContaining("[RPC] Request failed"));
231
+ done();
232
+ },
233
+ });
234
+ });
235
+ it("должен обработать ошибку в WebSocket контексте", (done) => {
236
+ const mockClient = { id: "test-client-id" };
237
+ const error = new Error("Test error");
238
+ executionContext.getType = jest.fn().mockReturnValue(ContextType.WS);
239
+ executionContext.switchToWs = jest.fn().mockReturnValue({
240
+ getClient: jest.fn().mockReturnValue(mockClient),
241
+ getData: jest.fn().mockReturnValue({ test: "data" }),
242
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
243
+ });
244
+ callHandler.handle.mockReturnValue(throwError(() => error));
245
+ const result = interceptor.intercept(executionContext, callHandler);
246
+ result.subscribe({
247
+ error: (err) => {
248
+ expect(err).toBe(error);
249
+ expect(loggerService.error).toHaveBeenCalledWith(expect.stringContaining("[WS] Event failed"));
250
+ done();
251
+ },
252
+ });
253
+ });
254
+ });
255
+ });
256
+ //# sourceMappingURL=unified.interceptor.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unified.interceptor.spec.js","sourceRoot":"","sources":["../../../src/interceptors/__tests__/unified.interceptor.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=websocket-logging.interceptor.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-logging.interceptor.spec.d.ts","sourceRoot":"","sources":["../../../src/interceptors/__tests__/websocket-logging.interceptor.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,119 @@
1
+ import { of, throwError } from "rxjs";
2
+ import SocketError from "../../errors/socket.error.js";
3
+ import WebSocketLoggingInterceptor from "../../interceptors/websocket-logging.interceptor.js";
4
+ describe("WebSocketLoggingInterceptor", () => {
5
+ let handler;
6
+ let loggerService;
7
+ let executionContext;
8
+ let callHandler;
9
+ let mockClient;
10
+ beforeEach(() => {
11
+ loggerService = {
12
+ log: jest.fn(),
13
+ error: jest.fn(),
14
+ warn: jest.fn(),
15
+ debug: jest.fn(),
16
+ setContext: jest.fn(),
17
+ };
18
+ handler = new WebSocketLoggingInterceptor(loggerService);
19
+ mockClient = {
20
+ id: "test-client-id",
21
+ };
22
+ executionContext = {
23
+ switchToWs: jest.fn(),
24
+ };
25
+ callHandler = {
26
+ handle: jest.fn(),
27
+ };
28
+ });
29
+ describe("конструктор", () => {
30
+ it("должен создать экземпляр обработчика", () => {
31
+ expect(handler).toBeInstanceOf(WebSocketLoggingInterceptor);
32
+ });
33
+ });
34
+ describe("intercept", () => {
35
+ it("должен логировать входящий WebSocket запрос и успешное выполнение", (done) => {
36
+ executionContext.switchToWs = jest.fn().mockReturnValue({
37
+ getClient: jest.fn().mockReturnValue(mockClient),
38
+ getData: jest.fn().mockReturnValue({ test: "data" }),
39
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
40
+ });
41
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
42
+ const result = handler.intercept(executionContext, callHandler);
43
+ result.subscribe({
44
+ next: (value) => {
45
+ expect(value).toEqual({ result: "success" });
46
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[WS] Incoming event [pattern: test-pattern]"));
47
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[WS] Event completed [pattern: test-pattern"));
48
+ done();
49
+ },
50
+ });
51
+ });
52
+ it("должен логировать ошибку при неудачном выполнении WebSocket запроса", (done) => {
53
+ const error = new SocketError("Test error");
54
+ executionContext.switchToWs = jest.fn().mockReturnValue({
55
+ getClient: jest.fn().mockReturnValue(mockClient),
56
+ getData: jest.fn().mockReturnValue({ test: "data" }),
57
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
58
+ });
59
+ callHandler.handle.mockReturnValue(throwError(() => error));
60
+ const result = handler.intercept(executionContext, callHandler);
61
+ result.subscribe({
62
+ error: (err) => {
63
+ expect(err).toBe(error);
64
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[WS] Incoming event [pattern: test-pattern]"));
65
+ expect(loggerService.error).toHaveBeenCalledWith(expect.stringContaining("[WS] Event failed [pattern: test-pattern"));
66
+ done();
67
+ },
68
+ });
69
+ });
70
+ it("должен использовать 'unknown' pattern, если pattern не найден", (done) => {
71
+ executionContext.switchToWs = jest.fn().mockReturnValue({
72
+ getClient: jest.fn().mockReturnValue(mockClient),
73
+ getData: jest.fn().mockReturnValue({ test: "data" }),
74
+ getPattern: jest.fn().mockReturnValue(null),
75
+ });
76
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
77
+ const result = handler.intercept(executionContext, callHandler);
78
+ result.subscribe({
79
+ next: () => {
80
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("[WS] Incoming event [pattern: unknown]"));
81
+ done();
82
+ },
83
+ });
84
+ });
85
+ it("должен использовать 'unknown' clientId, если client.id отсутствует", (done) => {
86
+ const clientWithoutId = {};
87
+ executionContext.switchToWs = jest.fn().mockReturnValue({
88
+ getClient: jest.fn().mockReturnValue(clientWithoutId),
89
+ getData: jest.fn().mockReturnValue({ test: "data" }),
90
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
91
+ });
92
+ callHandler.handle.mockReturnValue(of({ result: "success" }));
93
+ const result = handler.intercept(executionContext, callHandler);
94
+ result.subscribe({
95
+ next: () => {
96
+ expect(loggerService.log).toHaveBeenCalledWith(expect.stringContaining("client [unknown]"));
97
+ done();
98
+ },
99
+ });
100
+ });
101
+ it("должен обработать ошибку не типа Error", (done) => {
102
+ const error = "String error";
103
+ executionContext.switchToWs = jest.fn().mockReturnValue({
104
+ getClient: jest.fn().mockReturnValue(mockClient),
105
+ getData: jest.fn().mockReturnValue({ test: "data" }),
106
+ getPattern: jest.fn().mockReturnValue("test-pattern"),
107
+ });
108
+ callHandler.handle.mockReturnValue(throwError(() => error));
109
+ const result = handler.intercept(executionContext, callHandler);
110
+ result.subscribe({
111
+ error: () => {
112
+ expect(loggerService.error).toHaveBeenCalledWith(expect.stringContaining("String error"));
113
+ done();
114
+ },
115
+ });
116
+ });
117
+ });
118
+ });
119
+ //# sourceMappingURL=websocket-logging.interceptor.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-logging.interceptor.spec.js","sourceRoot":"","sources":["../../../src/interceptors/__tests__/websocket-logging.interceptor.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { CallHandler, ExecutionContext, NestInterceptor } from "@nestjs/common";
2
+ import { Observable } from "rxjs";
3
+ export default class CompressionInterceptor implements NestInterceptor {
4
+ private readonly threshold;
5
+ private readonly minCompressionRatio;
6
+ constructor(threshold?: number, // Порог размера в байтах
7
+ minCompressionRatio?: number);
8
+ intercept(context: ExecutionContext, next: CallHandler): Observable<unknown>;
9
+ }
10
+ //# sourceMappingURL=compression.interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compression.interceptor.d.ts","sourceRoot":"","sources":["../../src/interceptors/compression.interceptor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAc,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAKlC,MAAM,CAAC,OAAO,OAAO,sBAAuB,YAAW,eAAe;IAEpE,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,mBAAmB;gBADnB,SAAS,GAAE,MAAa,EAAE,yBAAyB;IACnD,mBAAmB,GAAE,MAAY;IAGnD,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC;CA+B5E"}
@@ -0,0 +1,53 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ 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;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { gzipSync } from "zlib";
11
+ import { Injectable } from "@nestjs/common";
12
+ import { map } from "rxjs/operators";
13
+ // Interceptor для автоматического сжатия больших ответов
14
+ let CompressionInterceptor = class CompressionInterceptor {
15
+ threshold;
16
+ minCompressionRatio;
17
+ constructor(threshold = 1024, // Порог размера в байтах
18
+ minCompressionRatio = 0.8 // Минимальный коэффициент сжатия
19
+ ) {
20
+ this.threshold = threshold;
21
+ this.minCompressionRatio = minCompressionRatio;
22
+ }
23
+ intercept(context, next) {
24
+ return next.handle().pipe(map((data) => {
25
+ // Преобразуем данные в строку для проверки размера
26
+ const dataString = JSON.stringify(data);
27
+ const dataSize = Buffer.byteLength(dataString, "utf8");
28
+ // Если размер меньше порога, возвращаем без сжатия
29
+ if (dataSize < this.threshold) {
30
+ return data;
31
+ }
32
+ // Сжимаем данные
33
+ const compressed = gzipSync(dataString);
34
+ const compressedSize = compressed.length;
35
+ const compressionRatio = compressedSize / dataSize;
36
+ // Если сжатие неэффективно, возвращаем без сжатия
37
+ if (compressionRatio >= this.minCompressionRatio) {
38
+ return data;
39
+ }
40
+ // Устанавливаем заголовки для сжатого контента
41
+ const response = context.switchToHttp().getResponse();
42
+ response.setHeader("Content-Encoding", "gzip");
43
+ response.setHeader("Content-Type", "application/json");
44
+ return compressed;
45
+ }));
46
+ }
47
+ };
48
+ CompressionInterceptor = __decorate([
49
+ Injectable(),
50
+ __metadata("design:paramtypes", [Number, Number])
51
+ ], CompressionInterceptor);
52
+ export default CompressionInterceptor;
53
+ //# sourceMappingURL=compression.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compression.interceptor.js","sourceRoot":"","sources":["../../src/interceptors/compression.interceptor.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,OAAO,EAAiC,UAAU,EAAmB,MAAM,gBAAgB,CAAC;AAE5F,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErC,yDAAyD;AAE1C,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAExB;IACA;IAFlB,YACkB,YAAoB,IAAI,EAAE,yBAAyB;IACnD,sBAA8B,GAAG,CAAC,iCAAiC;;QADnE,cAAS,GAAT,SAAS,CAAe;QACxB,wBAAmB,GAAnB,mBAAmB,CAAc;IAChD,CAAC;IAEJ,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACrD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACxB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,mDAAmD;YACnD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACxC,MAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;YAEvD,mDAAmD;YACnD,IAAI,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;gBAC/B,OAAO,IAAI,CAAC;YACb,CAAC;YAED,iBAAiB;YACjB,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;YACxC,MAAM,cAAc,GAAG,UAAU,CAAC,MAAM,CAAC;YACzC,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,CAAC;YAEnD,kDAAkD;YAClD,IAAI,gBAAgB,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAClD,OAAO,IAAI,CAAC;YACb,CAAC;YAED,+CAA+C;YAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,WAAW,EAAE,CAAC;YACtD,QAAQ,CAAC,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC;YAC/C,QAAQ,CAAC,SAAS,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;YAEvD,OAAO,UAAU,CAAC;QACnB,CAAC,CAAC,CACF,CAAC;IACH,CAAC;CACD,CAAA;AArCoB,sBAAsB;IAD1C,UAAU,EAAE;;GACQ,sBAAsB,CAqC1C;eArCoB,sBAAsB"}
@@ -0,0 +1,9 @@
1
+ import type { LoggerService } from "@makebelieve21213-packages/logger";
2
+ import type { CallHandler, ExecutionContext } from "@nestjs/common";
3
+ import type { Observable } from "rxjs";
4
+ export default class HttpLoggingInterceptor {
5
+ private readonly loggerService;
6
+ constructor(loggerService: LoggerService);
7
+ intercept(context: ExecutionContext, next: CallHandler): Observable<unknown>;
8
+ }
9
+ //# sourceMappingURL=http-logging.interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-logging.interceptor.d.ts","sourceRoot":"","sources":["../../src/interceptors/http-logging.interceptor.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEpE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGvC,MAAM,CAAC,OAAO,OAAO,sBAAsB;IAC9B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAAb,aAAa,EAAE,aAAa;IAGzD,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC;CA4C5E"}
@@ -0,0 +1,41 @@
1
+ import { HttpStatus } from "@nestjs/common";
2
+ import { throwError } from "rxjs";
3
+ import { catchError, tap } from "rxjs/operators";
4
+ import HttpError from "../errors/http.error.js";
5
+ // Перехватчик для логирования HTTP запросов
6
+ export default class HttpLoggingInterceptor {
7
+ loggerService;
8
+ constructor(loggerService) {
9
+ this.loggerService = loggerService;
10
+ }
11
+ // Обрабатывает HTTP запрос и логирует его выполнение
12
+ intercept(context, next) {
13
+ const httpContext = context.switchToHttp();
14
+ const request = httpContext.getRequest();
15
+ const response = httpContext.getResponse();
16
+ const method = request.method || "UNKNOWN";
17
+ const url = request.url || request.originalUrl || "/unknown";
18
+ const userAgent = request.get("user-agent") || "unknown";
19
+ const ip = request.ip || request.socket.remoteAddress || "unknown";
20
+ const startTime = Date.now();
21
+ // Устанавливаем контекст перед логированием
22
+ this.loggerService.setContext(HttpLoggingInterceptor.name);
23
+ // Логируем входящий запрос
24
+ this.loggerService.log(`[HTTP] Incoming request [${method} ${url}] from ${ip} (${userAgent})`);
25
+ // Перехватываем выполнение и логируем результат
26
+ return next.handle().pipe(tap(() => {
27
+ const duration = Date.now() - startTime;
28
+ const statusCode = response.statusCode || HttpStatus.OK;
29
+ this.loggerService.log(`[HTTP] Request completed [${method} ${url}] ${statusCode} ${duration}ms`);
30
+ }), catchError((error) => {
31
+ const duration = Date.now() - startTime;
32
+ // Преобразуем ошибку в HttpError для извлечения статус кода и сообщения
33
+ const httpError = HttpError.fromUnknown(error);
34
+ const statusCode = httpError.getStatus();
35
+ this.loggerService.error(`[HTTP] Request failed [${method} ${url}] ${statusCode} ${duration}ms - ${httpError.message}`);
36
+ // Пробрасываем ошибку дальше для обработки фильтром
37
+ return throwError(() => error);
38
+ }));
39
+ }
40
+ }
41
+ //# sourceMappingURL=http-logging.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-logging.interceptor.js","sourceRoot":"","sources":["../../src/interceptors/http-logging.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,SAAS,MAAM,uBAAuB,CAAC;AAO9C,4CAA4C;AAC5C,MAAM,CAAC,OAAO,OAAO,sBAAsB;IACb;IAA7B,YAA6B,aAA4B;QAA5B,kBAAa,GAAb,aAAa,CAAe;IAAG,CAAC;IAE7D,qDAAqD;IACrD,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACrD,MAAM,WAAW,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;QAC3C,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAW,CAAC;QAClD,MAAM,QAAQ,GAAG,WAAW,CAAC,WAAW,EAAY,CAAC;QAErD,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,SAAS,CAAC;QAC3C,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,WAAW,IAAI,UAAU,CAAC;QAC7D,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,SAAS,CAAC;QACzD,MAAM,EAAE,GAAG,OAAO,CAAC,EAAE,IAAI,OAAO,CAAC,MAAM,CAAC,aAAa,IAAI,SAAS,CAAC;QACnE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAE7B,4CAA4C;QAC5C,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC;QAE3D,2BAA2B;QAC3B,IAAI,CAAC,aAAa,CAAC,GAAG,CACrB,4BAA4B,MAAM,IAAI,GAAG,UAAU,EAAE,KAAK,SAAS,GAAG,CACtE,CAAC;QAEF,gDAAgD;QAChD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACxB,GAAG,CAAC,GAAG,EAAE;YACR,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YACxC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,IAAI,UAAU,CAAC,EAAE,CAAC;YAExD,IAAI,CAAC,aAAa,CAAC,GAAG,CACrB,6BAA6B,MAAM,IAAI,GAAG,KAAK,UAAU,IAAI,QAAQ,IAAI,CACzE,CAAC;QACH,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAsB,EAAE,EAAE;YACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YACxC,wEAAwE;YACxE,MAAM,SAAS,GAAG,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC/C,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC;YAEzC,IAAI,CAAC,aAAa,CAAC,KAAK,CACvB,0BAA0B,MAAM,IAAI,GAAG,KAAK,UAAU,IAAI,QAAQ,QAAQ,SAAS,CAAC,OAAO,EAAE,CAC7F,CAAC;YAEF,oDAAoD;YACpD,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC,CAAC,CACF,CAAC;IACH,CAAC;CACD"}
@@ -0,0 +1,6 @@
1
+ import { CallHandler, ExecutionContext, NestInterceptor } from "@nestjs/common";
2
+ import { Observable } from "rxjs";
3
+ export default class RequestIdResponseInterceptor implements NestInterceptor {
4
+ intercept(context: ExecutionContext, next: CallHandler): Observable<unknown>;
5
+ }
6
+ //# sourceMappingURL=request-id-response.interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-id-response.interceptor.d.ts","sourceRoot":"","sources":["../../src/interceptors/request-id-response.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAc,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAMlC,MAAM,CAAC,OAAO,OAAO,4BAA6B,YAAW,eAAe;IAC3E,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC;CAa5E"}
@@ -0,0 +1,27 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ 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;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { Injectable } from "@nestjs/common";
8
+ import { tap } from "rxjs/operators";
9
+ import { getRequestIdFromContext } from "../utils/context.utils.js";
10
+ // Interceptor для добавления Request ID в заголовки ответов
11
+ let RequestIdResponseInterceptor = class RequestIdResponseInterceptor {
12
+ intercept(context, next) {
13
+ const requestId = getRequestIdFromContext(context);
14
+ const response = context.switchToHttp().getResponse();
15
+ return next.handle().pipe(tap(() => {
16
+ // Добавляем Request ID в заголовки ответа
17
+ if (requestId && requestId !== "unknown") {
18
+ response.setHeader("X-Request-ID", requestId);
19
+ }
20
+ }));
21
+ }
22
+ };
23
+ RequestIdResponseInterceptor = __decorate([
24
+ Injectable()
25
+ ], RequestIdResponseInterceptor);
26
+ export default RequestIdResponseInterceptor;
27
+ //# sourceMappingURL=request-id-response.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-id-response.interceptor.js","sourceRoot":"","sources":["../../src/interceptors/request-id-response.interceptor.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAiC,UAAU,EAAmB,MAAM,gBAAgB,CAAC;AAE5F,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAElE,4DAA4D;AAE7C,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IAChD,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACrD,MAAM,SAAS,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACnD,MAAM,QAAQ,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,WAAW,EAAE,CAAC;QAEtD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACxB,GAAG,CAAC,GAAG,EAAE;YACR,0CAA0C;YAC1C,IAAI,SAAS,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;gBAC1C,QAAQ,CAAC,SAAS,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;YAC/C,CAAC;QACF,CAAC,CAAC,CACF,CAAC;IACH,CAAC;CACD,CAAA;AAdoB,4BAA4B;IADhD,UAAU,EAAE;GACQ,4BAA4B,CAchD;eAdoB,4BAA4B"}
@@ -0,0 +1,8 @@
1
+ import { CallHandler, ExecutionContext, NestInterceptor } from "@nestjs/common";
2
+ import { Observable } from "rxjs";
3
+ import type { StandardResponse } from "../types/http-response.js";
4
+ export default class ResponseInterceptor<T> implements NestInterceptor<T, StandardResponse<T>> {
5
+ constructor();
6
+ intercept(context: ExecutionContext, next: CallHandler): Observable<StandardResponse<T>>;
7
+ }
8
+ //# sourceMappingURL=response.interceptor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"response.interceptor.d.ts","sourceRoot":"","sources":["../../src/interceptors/response.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAc,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGlC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAIhE,MAAM,CAAC,OAAO,OAAO,mBAAmB,CAAC,CAAC,CACzC,YAAW,eAAe,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC;;IAIlD,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,GAAG,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;CAyBxF"}