nestlens 0.1.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 (359) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +145 -0
  3. package/dist/__tests__/api/api.controller.spec.d.ts +2 -0
  4. package/dist/__tests__/api/api.controller.spec.d.ts.map +1 -0
  5. package/dist/__tests__/api/api.controller.spec.js +982 -0
  6. package/dist/__tests__/api/api.controller.spec.js.map +1 -0
  7. package/dist/__tests__/api/api.guard.spec.d.ts +2 -0
  8. package/dist/__tests__/api/api.guard.spec.d.ts.map +1 -0
  9. package/dist/__tests__/api/api.guard.spec.js +572 -0
  10. package/dist/__tests__/api/api.guard.spec.js.map +1 -0
  11. package/dist/__tests__/api/dashboard.controller.spec.d.ts +2 -0
  12. package/dist/__tests__/api/dashboard.controller.spec.d.ts.map +1 -0
  13. package/dist/__tests__/api/dashboard.controller.spec.js +474 -0
  14. package/dist/__tests__/api/dashboard.controller.spec.js.map +1 -0
  15. package/dist/__tests__/api/tag.controller.spec.d.ts +2 -0
  16. package/dist/__tests__/api/tag.controller.spec.d.ts.map +1 -0
  17. package/dist/__tests__/api/tag.controller.spec.js +280 -0
  18. package/dist/__tests__/api/tag.controller.spec.js.map +1 -0
  19. package/dist/__tests__/collector.service.spec.d.ts +2 -0
  20. package/dist/__tests__/collector.service.spec.d.ts.map +1 -0
  21. package/dist/__tests__/collector.service.spec.js +240 -0
  22. package/dist/__tests__/collector.service.spec.js.map +1 -0
  23. package/dist/__tests__/core/collector.service.spec.d.ts +2 -0
  24. package/dist/__tests__/core/collector.service.spec.d.ts.map +1 -0
  25. package/dist/__tests__/core/collector.service.spec.js +526 -0
  26. package/dist/__tests__/core/collector.service.spec.js.map +1 -0
  27. package/dist/__tests__/core/family-hash.service.spec.d.ts +2 -0
  28. package/dist/__tests__/core/family-hash.service.spec.d.ts.map +1 -0
  29. package/dist/__tests__/core/family-hash.service.spec.js +1117 -0
  30. package/dist/__tests__/core/family-hash.service.spec.js.map +1 -0
  31. package/dist/__tests__/core/pruning.service.spec.d.ts +2 -0
  32. package/dist/__tests__/core/pruning.service.spec.d.ts.map +1 -0
  33. package/dist/__tests__/core/pruning.service.spec.js +224 -0
  34. package/dist/__tests__/core/pruning.service.spec.js.map +1 -0
  35. package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts +2 -0
  36. package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts.map +1 -0
  37. package/dist/__tests__/core/storage/sqlite.storage.spec.js +853 -0
  38. package/dist/__tests__/core/storage/sqlite.storage.spec.js.map +1 -0
  39. package/dist/__tests__/core/tag.service.spec.d.ts +2 -0
  40. package/dist/__tests__/core/tag.service.spec.d.ts.map +1 -0
  41. package/dist/__tests__/core/tag.service.spec.js +994 -0
  42. package/dist/__tests__/core/tag.service.spec.js.map +1 -0
  43. package/dist/__tests__/family-hash.service.spec.d.ts +2 -0
  44. package/dist/__tests__/family-hash.service.spec.d.ts.map +1 -0
  45. package/dist/__tests__/family-hash.service.spec.js +325 -0
  46. package/dist/__tests__/family-hash.service.spec.js.map +1 -0
  47. package/dist/__tests__/filters/api-filters.spec.d.ts +2 -0
  48. package/dist/__tests__/filters/api-filters.spec.d.ts.map +1 -0
  49. package/dist/__tests__/filters/api-filters.spec.js +172 -0
  50. package/dist/__tests__/filters/api-filters.spec.js.map +1 -0
  51. package/dist/__tests__/filters/entry-factories.d.ts +20 -0
  52. package/dist/__tests__/filters/entry-factories.d.ts.map +1 -0
  53. package/dist/__tests__/filters/entry-factories.js +288 -0
  54. package/dist/__tests__/filters/entry-factories.js.map +1 -0
  55. package/dist/__tests__/filters/filter-contract.spec.d.ts +2 -0
  56. package/dist/__tests__/filters/filter-contract.spec.d.ts.map +1 -0
  57. package/dist/__tests__/filters/filter-contract.spec.js +230 -0
  58. package/dist/__tests__/filters/filter-contract.spec.js.map +1 -0
  59. package/dist/__tests__/filters/filter-test-data.d.ts +26 -0
  60. package/dist/__tests__/filters/filter-test-data.d.ts.map +1 -0
  61. package/dist/__tests__/filters/filter-test-data.js +374 -0
  62. package/dist/__tests__/filters/filter-test-data.js.map +1 -0
  63. package/dist/__tests__/filters/storage-filters.spec.d.ts +2 -0
  64. package/dist/__tests__/filters/storage-filters.spec.d.ts.map +1 -0
  65. package/dist/__tests__/filters/storage-filters.spec.js +699 -0
  66. package/dist/__tests__/filters/storage-filters.spec.js.map +1 -0
  67. package/dist/__tests__/filters/test-utils.d.ts +23 -0
  68. package/dist/__tests__/filters/test-utils.d.ts.map +1 -0
  69. package/dist/__tests__/filters/test-utils.js +54 -0
  70. package/dist/__tests__/filters/test-utils.js.map +1 -0
  71. package/dist/__tests__/nestlens.module.spec.d.ts +2 -0
  72. package/dist/__tests__/nestlens.module.spec.d.ts.map +1 -0
  73. package/dist/__tests__/nestlens.module.spec.js +620 -0
  74. package/dist/__tests__/nestlens.module.spec.js.map +1 -0
  75. package/dist/__tests__/pruning.service.spec.d.ts +2 -0
  76. package/dist/__tests__/pruning.service.spec.d.ts.map +1 -0
  77. package/dist/__tests__/pruning.service.spec.js +142 -0
  78. package/dist/__tests__/pruning.service.spec.js.map +1 -0
  79. package/dist/__tests__/setup.d.ts +7 -0
  80. package/dist/__tests__/setup.d.ts.map +1 -0
  81. package/dist/__tests__/setup.js +24 -0
  82. package/dist/__tests__/setup.js.map +1 -0
  83. package/dist/__tests__/tag.service.spec.d.ts +2 -0
  84. package/dist/__tests__/tag.service.spec.d.ts.map +1 -0
  85. package/dist/__tests__/tag.service.spec.js +482 -0
  86. package/dist/__tests__/tag.service.spec.js.map +1 -0
  87. package/dist/__tests__/watchers/batch.watcher.spec.d.ts +2 -0
  88. package/dist/__tests__/watchers/batch.watcher.spec.d.ts.map +1 -0
  89. package/dist/__tests__/watchers/batch.watcher.spec.js +515 -0
  90. package/dist/__tests__/watchers/batch.watcher.spec.js.map +1 -0
  91. package/dist/__tests__/watchers/cache.watcher.spec.d.ts +2 -0
  92. package/dist/__tests__/watchers/cache.watcher.spec.d.ts.map +1 -0
  93. package/dist/__tests__/watchers/cache.watcher.spec.js +395 -0
  94. package/dist/__tests__/watchers/cache.watcher.spec.js.map +1 -0
  95. package/dist/__tests__/watchers/command.watcher.spec.d.ts +2 -0
  96. package/dist/__tests__/watchers/command.watcher.spec.d.ts.map +1 -0
  97. package/dist/__tests__/watchers/command.watcher.spec.js +598 -0
  98. package/dist/__tests__/watchers/command.watcher.spec.js.map +1 -0
  99. package/dist/__tests__/watchers/dump.watcher.spec.d.ts +2 -0
  100. package/dist/__tests__/watchers/dump.watcher.spec.d.ts.map +1 -0
  101. package/dist/__tests__/watchers/dump.watcher.spec.js +724 -0
  102. package/dist/__tests__/watchers/dump.watcher.spec.js.map +1 -0
  103. package/dist/__tests__/watchers/event.watcher.spec.d.ts +2 -0
  104. package/dist/__tests__/watchers/event.watcher.spec.d.ts.map +1 -0
  105. package/dist/__tests__/watchers/event.watcher.spec.js +316 -0
  106. package/dist/__tests__/watchers/event.watcher.spec.js.map +1 -0
  107. package/dist/__tests__/watchers/exception.watcher.spec.d.ts +2 -0
  108. package/dist/__tests__/watchers/exception.watcher.spec.d.ts.map +1 -0
  109. package/dist/__tests__/watchers/exception.watcher.spec.js +495 -0
  110. package/dist/__tests__/watchers/exception.watcher.spec.js.map +1 -0
  111. package/dist/__tests__/watchers/gate.watcher.spec.d.ts +2 -0
  112. package/dist/__tests__/watchers/gate.watcher.spec.d.ts.map +1 -0
  113. package/dist/__tests__/watchers/gate.watcher.spec.js +683 -0
  114. package/dist/__tests__/watchers/gate.watcher.spec.js.map +1 -0
  115. package/dist/__tests__/watchers/http-client.watcher.spec.d.ts +2 -0
  116. package/dist/__tests__/watchers/http-client.watcher.spec.d.ts.map +1 -0
  117. package/dist/__tests__/watchers/http-client.watcher.spec.js +888 -0
  118. package/dist/__tests__/watchers/http-client.watcher.spec.js.map +1 -0
  119. package/dist/__tests__/watchers/job.watcher.spec.d.ts +2 -0
  120. package/dist/__tests__/watchers/job.watcher.spec.d.ts.map +1 -0
  121. package/dist/__tests__/watchers/job.watcher.spec.js +513 -0
  122. package/dist/__tests__/watchers/job.watcher.spec.js.map +1 -0
  123. package/dist/__tests__/watchers/log.watcher.spec.d.ts +2 -0
  124. package/dist/__tests__/watchers/log.watcher.spec.d.ts.map +1 -0
  125. package/dist/__tests__/watchers/log.watcher.spec.js +428 -0
  126. package/dist/__tests__/watchers/log.watcher.spec.js.map +1 -0
  127. package/dist/__tests__/watchers/mail.watcher.spec.d.ts +2 -0
  128. package/dist/__tests__/watchers/mail.watcher.spec.d.ts.map +1 -0
  129. package/dist/__tests__/watchers/mail.watcher.spec.js +425 -0
  130. package/dist/__tests__/watchers/mail.watcher.spec.js.map +1 -0
  131. package/dist/__tests__/watchers/model.watcher.spec.d.ts +2 -0
  132. package/dist/__tests__/watchers/model.watcher.spec.d.ts.map +1 -0
  133. package/dist/__tests__/watchers/model.watcher.spec.js +675 -0
  134. package/dist/__tests__/watchers/model.watcher.spec.js.map +1 -0
  135. package/dist/__tests__/watchers/notification.watcher.spec.d.ts +2 -0
  136. package/dist/__tests__/watchers/notification.watcher.spec.d.ts.map +1 -0
  137. package/dist/__tests__/watchers/notification.watcher.spec.js +595 -0
  138. package/dist/__tests__/watchers/notification.watcher.spec.js.map +1 -0
  139. package/dist/__tests__/watchers/query/types.spec.d.ts +2 -0
  140. package/dist/__tests__/watchers/query/types.spec.d.ts.map +1 -0
  141. package/dist/__tests__/watchers/query/types.spec.js +292 -0
  142. package/dist/__tests__/watchers/query/types.spec.js.map +1 -0
  143. package/dist/__tests__/watchers/query.watcher.spec.d.ts +2 -0
  144. package/dist/__tests__/watchers/query.watcher.spec.d.ts.map +1 -0
  145. package/dist/__tests__/watchers/query.watcher.spec.js +597 -0
  146. package/dist/__tests__/watchers/query.watcher.spec.js.map +1 -0
  147. package/dist/__tests__/watchers/redis.watcher.spec.d.ts +2 -0
  148. package/dist/__tests__/watchers/redis.watcher.spec.d.ts.map +1 -0
  149. package/dist/__tests__/watchers/redis.watcher.spec.js +634 -0
  150. package/dist/__tests__/watchers/redis.watcher.spec.js.map +1 -0
  151. package/dist/__tests__/watchers/request.watcher.spec.d.ts +2 -0
  152. package/dist/__tests__/watchers/request.watcher.spec.d.ts.map +1 -0
  153. package/dist/__tests__/watchers/request.watcher.spec.js +1017 -0
  154. package/dist/__tests__/watchers/request.watcher.spec.js.map +1 -0
  155. package/dist/__tests__/watchers/schedule.watcher.spec.d.ts +2 -0
  156. package/dist/__tests__/watchers/schedule.watcher.spec.d.ts.map +1 -0
  157. package/dist/__tests__/watchers/schedule.watcher.spec.js +338 -0
  158. package/dist/__tests__/watchers/schedule.watcher.spec.js.map +1 -0
  159. package/dist/__tests__/watchers/view.watcher.spec.d.ts +2 -0
  160. package/dist/__tests__/watchers/view.watcher.spec.d.ts.map +1 -0
  161. package/dist/__tests__/watchers/view.watcher.spec.js +564 -0
  162. package/dist/__tests__/watchers/view.watcher.spec.js.map +1 -0
  163. package/dist/api/api.controller.d.ts +193 -0
  164. package/dist/api/api.controller.d.ts.map +1 -0
  165. package/dist/api/api.controller.js +562 -0
  166. package/dist/api/api.controller.js.map +1 -0
  167. package/dist/api/api.guard.d.ts +77 -0
  168. package/dist/api/api.guard.d.ts.map +1 -0
  169. package/dist/api/api.guard.js +294 -0
  170. package/dist/api/api.guard.js.map +1 -0
  171. package/dist/api/dashboard.controller.d.ts +49 -0
  172. package/dist/api/dashboard.controller.d.ts.map +1 -0
  173. package/dist/api/dashboard.controller.js +472 -0
  174. package/dist/api/dashboard.controller.js.map +1 -0
  175. package/dist/api/index.d.ts +5 -0
  176. package/dist/api/index.d.ts.map +1 -0
  177. package/dist/api/index.js +21 -0
  178. package/dist/api/index.js.map +1 -0
  179. package/dist/api/tag.controller.d.ts +65 -0
  180. package/dist/api/tag.controller.d.ts.map +1 -0
  181. package/dist/api/tag.controller.js +149 -0
  182. package/dist/api/tag.controller.js.map +1 -0
  183. package/dist/core/collector.service.d.ts +80 -0
  184. package/dist/core/collector.service.d.ts.map +1 -0
  185. package/dist/core/collector.service.js +255 -0
  186. package/dist/core/collector.service.js.map +1 -0
  187. package/dist/core/family-hash.service.d.ts +64 -0
  188. package/dist/core/family-hash.service.d.ts.map +1 -0
  189. package/dist/core/family-hash.service.js +281 -0
  190. package/dist/core/family-hash.service.js.map +1 -0
  191. package/dist/core/index.d.ts +4 -0
  192. package/dist/core/index.d.ts.map +1 -0
  193. package/dist/core/index.js +20 -0
  194. package/dist/core/index.js.map +1 -0
  195. package/dist/core/pruning.service.d.ts +16 -0
  196. package/dist/core/pruning.service.d.ts.map +1 -0
  197. package/dist/core/pruning.service.js +71 -0
  198. package/dist/core/pruning.service.js.map +1 -0
  199. package/dist/core/storage/index.d.ts +3 -0
  200. package/dist/core/storage/index.d.ts.map +1 -0
  201. package/dist/core/storage/index.js +19 -0
  202. package/dist/core/storage/index.js.map +1 -0
  203. package/dist/core/storage/sqlite.storage.d.ts +60 -0
  204. package/dist/core/storage/sqlite.storage.d.ts.map +1 -0
  205. package/dist/core/storage/sqlite.storage.js +929 -0
  206. package/dist/core/storage/sqlite.storage.js.map +1 -0
  207. package/dist/core/storage/storage.interface.d.ts +122 -0
  208. package/dist/core/storage/storage.interface.d.ts.map +1 -0
  209. package/dist/core/storage/storage.interface.js +5 -0
  210. package/dist/core/storage/storage.interface.js.map +1 -0
  211. package/dist/core/tag.service.d.ts +71 -0
  212. package/dist/core/tag.service.d.ts.map +1 -0
  213. package/dist/core/tag.service.js +568 -0
  214. package/dist/core/tag.service.js.map +1 -0
  215. package/dist/dashboard/public/assets/BatchesPage-DFT4fKlJ.js +1 -0
  216. package/dist/dashboard/public/assets/CachePage-CRy1Tjb8.js +1 -0
  217. package/dist/dashboard/public/assets/ClickableBadge-CV5J3THx.js +1 -0
  218. package/dist/dashboard/public/assets/CommandsPage-DdRnTm-W.js +1 -0
  219. package/dist/dashboard/public/assets/DashboardPage-CjaRZXYy.js +26 -0
  220. package/dist/dashboard/public/assets/DataTable-B6o9H8lh.js +88 -0
  221. package/dist/dashboard/public/assets/DumpsPage-DO8y1RTg.js +1 -0
  222. package/dist/dashboard/public/assets/EntryDetailPage-By-YcAGL.js +125 -0
  223. package/dist/dashboard/public/assets/EventsPage-u-r4AiT4.js +1 -0
  224. package/dist/dashboard/public/assets/ExceptionsPage-DXUcARr1.js +6 -0
  225. package/dist/dashboard/public/assets/GatesPage-DpeP7CDZ.js +1 -0
  226. package/dist/dashboard/public/assets/HttpClientPage-BJ4-5E6t.js +1 -0
  227. package/dist/dashboard/public/assets/JobsPage-Dv3KaX2x.js +1 -0
  228. package/dist/dashboard/public/assets/LogsPage-D0Q3yDb1.js +1 -0
  229. package/dist/dashboard/public/assets/MailPage-Bf8C6WF6.js +1 -0
  230. package/dist/dashboard/public/assets/ModelsPage-BMHncI5y.js +1 -0
  231. package/dist/dashboard/public/assets/NotificationsPage-D5-I-Oxb.js +1 -0
  232. package/dist/dashboard/public/assets/QueriesPage-oNp0i6Gt.js +1 -0
  233. package/dist/dashboard/public/assets/RedisPage-_GeS2OD8.js +1 -0
  234. package/dist/dashboard/public/assets/RequestsPage-BCwqu9US.js +1 -0
  235. package/dist/dashboard/public/assets/SchedulePage-CR0P-oX6.js +1 -0
  236. package/dist/dashboard/public/assets/ViewsPage-Dsy5ECRA.js +1 -0
  237. package/dist/dashboard/public/assets/calendar-DfK3x-6B.js +6 -0
  238. package/dist/dashboard/public/assets/circle-check-big-DcsYW8y8.js +6 -0
  239. package/dist/dashboard/public/assets/format-BFldcnCk.js +1 -0
  240. package/dist/dashboard/public/assets/index-DmeA1maE.css +1 -0
  241. package/dist/dashboard/public/assets/index-rkbGYdU7.js +351 -0
  242. package/dist/dashboard/public/assets/types-Cldoe2db.js +1 -0
  243. package/dist/dashboard/public/assets/vendor-B2nVRih0.js +43 -0
  244. package/dist/dashboard/public/assets/zap-DqtRi0JM.js +6 -0
  245. package/dist/dashboard/public/index.html +15 -0
  246. package/dist/dashboard/public/nestlens-icon.svg +9 -0
  247. package/dist/index.d.ts +22 -0
  248. package/dist/index.d.ts.map +1 -0
  249. package/dist/index.js +69 -0
  250. package/dist/index.js.map +1 -0
  251. package/dist/nestlens.config.d.ts +216 -0
  252. package/dist/nestlens.config.d.ts.map +1 -0
  253. package/dist/nestlens.config.js +57 -0
  254. package/dist/nestlens.config.js.map +1 -0
  255. package/dist/nestlens.module.d.ts +10 -0
  256. package/dist/nestlens.module.d.ts.map +1 -0
  257. package/dist/nestlens.module.js +211 -0
  258. package/dist/nestlens.module.js.map +1 -0
  259. package/dist/types/entry.types.d.ts +368 -0
  260. package/dist/types/entry.types.d.ts.map +1 -0
  261. package/dist/types/entry.types.js +3 -0
  262. package/dist/types/entry.types.js.map +1 -0
  263. package/dist/types/index.d.ts +4 -0
  264. package/dist/types/index.d.ts.map +1 -0
  265. package/dist/types/index.js +20 -0
  266. package/dist/types/index.js.map +1 -0
  267. package/dist/types/request.types.d.ts +9 -0
  268. package/dist/types/request.types.d.ts.map +1 -0
  269. package/dist/types/request.types.js +3 -0
  270. package/dist/types/request.types.js.map +1 -0
  271. package/dist/types/tag.types.d.ts +32 -0
  272. package/dist/types/tag.types.d.ts.map +1 -0
  273. package/dist/types/tag.types.js +3 -0
  274. package/dist/types/tag.types.js.map +1 -0
  275. package/dist/watchers/batch.watcher.d.ts +48 -0
  276. package/dist/watchers/batch.watcher.d.ts.map +1 -0
  277. package/dist/watchers/batch.watcher.js +185 -0
  278. package/dist/watchers/batch.watcher.js.map +1 -0
  279. package/dist/watchers/cache.watcher.d.ts +19 -0
  280. package/dist/watchers/cache.watcher.d.ts.map +1 -0
  281. package/dist/watchers/cache.watcher.js +158 -0
  282. package/dist/watchers/cache.watcher.js.map +1 -0
  283. package/dist/watchers/command.watcher.d.ts +32 -0
  284. package/dist/watchers/command.watcher.d.ts.map +1 -0
  285. package/dist/watchers/command.watcher.js +174 -0
  286. package/dist/watchers/command.watcher.js.map +1 -0
  287. package/dist/watchers/dump.watcher.d.ts +52 -0
  288. package/dist/watchers/dump.watcher.d.ts.map +1 -0
  289. package/dist/watchers/dump.watcher.js +234 -0
  290. package/dist/watchers/dump.watcher.js.map +1 -0
  291. package/dist/watchers/event.watcher.d.ts +20 -0
  292. package/dist/watchers/event.watcher.d.ts.map +1 -0
  293. package/dist/watchers/event.watcher.js +123 -0
  294. package/dist/watchers/event.watcher.js.map +1 -0
  295. package/dist/watchers/exception.watcher.d.ts +15 -0
  296. package/dist/watchers/exception.watcher.d.ts.map +1 -0
  297. package/dist/watchers/exception.watcher.js +117 -0
  298. package/dist/watchers/exception.watcher.js.map +1 -0
  299. package/dist/watchers/gate.watcher.d.ts +40 -0
  300. package/dist/watchers/gate.watcher.d.ts.map +1 -0
  301. package/dist/watchers/gate.watcher.js +200 -0
  302. package/dist/watchers/gate.watcher.js.map +1 -0
  303. package/dist/watchers/http-client.watcher.d.ts +34 -0
  304. package/dist/watchers/http-client.watcher.d.ts.map +1 -0
  305. package/dist/watchers/http-client.watcher.js +259 -0
  306. package/dist/watchers/http-client.watcher.js.map +1 -0
  307. package/dist/watchers/index.d.ts +19 -0
  308. package/dist/watchers/index.d.ts.map +1 -0
  309. package/dist/watchers/index.js +35 -0
  310. package/dist/watchers/index.js.map +1 -0
  311. package/dist/watchers/job.watcher.d.ts +27 -0
  312. package/dist/watchers/job.watcher.d.ts.map +1 -0
  313. package/dist/watchers/job.watcher.js +190 -0
  314. package/dist/watchers/job.watcher.js.map +1 -0
  315. package/dist/watchers/log.watcher.d.ts +26 -0
  316. package/dist/watchers/log.watcher.d.ts.map +1 -0
  317. package/dist/watchers/log.watcher.js +122 -0
  318. package/dist/watchers/log.watcher.js.map +1 -0
  319. package/dist/watchers/mail.watcher.d.ts +26 -0
  320. package/dist/watchers/mail.watcher.d.ts.map +1 -0
  321. package/dist/watchers/mail.watcher.js +154 -0
  322. package/dist/watchers/mail.watcher.js.map +1 -0
  323. package/dist/watchers/model.watcher.d.ts +54 -0
  324. package/dist/watchers/model.watcher.d.ts.map +1 -0
  325. package/dist/watchers/model.watcher.js +343 -0
  326. package/dist/watchers/model.watcher.js.map +1 -0
  327. package/dist/watchers/notification.watcher.d.ts +48 -0
  328. package/dist/watchers/notification.watcher.d.ts.map +1 -0
  329. package/dist/watchers/notification.watcher.js +215 -0
  330. package/dist/watchers/notification.watcher.js.map +1 -0
  331. package/dist/watchers/query/index.d.ts +3 -0
  332. package/dist/watchers/query/index.d.ts.map +1 -0
  333. package/dist/watchers/query/index.js +19 -0
  334. package/dist/watchers/query/index.js.map +1 -0
  335. package/dist/watchers/query/query.watcher.d.ts +27 -0
  336. package/dist/watchers/query/query.watcher.d.ts.map +1 -0
  337. package/dist/watchers/query/query.watcher.js +167 -0
  338. package/dist/watchers/query/query.watcher.js.map +1 -0
  339. package/dist/watchers/query/types.d.ts +60 -0
  340. package/dist/watchers/query/types.d.ts.map +1 -0
  341. package/dist/watchers/query/types.js +55 -0
  342. package/dist/watchers/query/types.js.map +1 -0
  343. package/dist/watchers/redis.watcher.d.ts +43 -0
  344. package/dist/watchers/redis.watcher.d.ts.map +1 -0
  345. package/dist/watchers/redis.watcher.js +225 -0
  346. package/dist/watchers/redis.watcher.js.map +1 -0
  347. package/dist/watchers/request.watcher.d.ts +21 -0
  348. package/dist/watchers/request.watcher.d.ts.map +1 -0
  349. package/dist/watchers/request.watcher.js +287 -0
  350. package/dist/watchers/request.watcher.js.map +1 -0
  351. package/dist/watchers/schedule.watcher.d.ts +25 -0
  352. package/dist/watchers/schedule.watcher.d.ts.map +1 -0
  353. package/dist/watchers/schedule.watcher.js +168 -0
  354. package/dist/watchers/schedule.watcher.js.map +1 -0
  355. package/dist/watchers/view.watcher.d.ts +51 -0
  356. package/dist/watchers/view.watcher.d.ts.map +1 -0
  357. package/dist/watchers/view.watcher.js +219 -0
  358. package/dist/watchers/view.watcher.js.map +1 -0
  359. package/package.json +86 -0
@@ -0,0 +1,699 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("reflect-metadata");
4
+ const test_utils_1 = require("./test-utils");
5
+ const entry_factories_1 = require("./entry-factories");
6
+ describe('Storage Filters', () => {
7
+ let storage;
8
+ beforeEach(() => {
9
+ storage = (0, test_utils_1.createTestStorage)();
10
+ });
11
+ afterEach(async () => {
12
+ await storage.close();
13
+ });
14
+ // ==================== LOG FILTERS ====================
15
+ describe('Log Filters', () => {
16
+ describe('levels', () => {
17
+ it('returns only entries matching specified log levels', async () => {
18
+ const entries = [
19
+ (0, entry_factories_1.createLogEntry)({ level: 'error', message: 'Error 1' }),
20
+ (0, entry_factories_1.createLogEntry)({ level: 'warn', message: 'Warning 1' }),
21
+ (0, entry_factories_1.createLogEntry)({ level: 'debug', message: 'Debug 1' }),
22
+ ];
23
+ await (0, test_utils_1.seedStorage)(storage, entries);
24
+ const result = await storage.findWithCursor('log', {
25
+ filters: { levels: ['error', 'warn'] },
26
+ });
27
+ expect(result.data).toHaveLength(2);
28
+ expect(result.data.every((e) => ['error', 'warn'].includes(e.payload.level))).toBe(true);
29
+ });
30
+ it('excludes non-matching entries', async () => {
31
+ await (0, test_utils_1.seedStorage)(storage, [
32
+ (0, entry_factories_1.createLogEntry)({ level: 'debug' }),
33
+ (0, entry_factories_1.createLogEntry)({ level: 'verbose' }),
34
+ ]);
35
+ const result = await storage.findWithCursor('log', {
36
+ filters: { levels: ['error'] },
37
+ });
38
+ expect(result.data).toHaveLength(0);
39
+ });
40
+ });
41
+ describe('contexts', () => {
42
+ it('returns only entries matching specified contexts', async () => {
43
+ const entries = [
44
+ (0, entry_factories_1.createLogEntry)({ context: 'UserService' }),
45
+ (0, entry_factories_1.createLogEntry)({ context: 'AuthController' }),
46
+ (0, entry_factories_1.createLogEntry)({ context: 'CacheModule' }),
47
+ ];
48
+ await (0, test_utils_1.seedStorage)(storage, entries);
49
+ const result = await storage.findWithCursor('log', {
50
+ filters: { contexts: ['UserService', 'AuthController'] },
51
+ });
52
+ expect(result.data).toHaveLength(2);
53
+ });
54
+ });
55
+ });
56
+ // ==================== QUERY FILTERS ====================
57
+ describe('Query Filters', () => {
58
+ describe('queryTypes', () => {
59
+ it('filters queries by SQL type prefix', async () => {
60
+ const entries = [
61
+ (0, entry_factories_1.createQueryEntry)({ query: 'SELECT * FROM users' }),
62
+ (0, entry_factories_1.createQueryEntry)({ query: 'SELECT id FROM orders' }),
63
+ (0, entry_factories_1.createQueryEntry)({ query: 'INSERT INTO users VALUES(1)' }),
64
+ ];
65
+ await (0, test_utils_1.seedStorage)(storage, entries);
66
+ const result = await storage.findWithCursor('query', {
67
+ filters: { queryTypes: ['SELECT'] },
68
+ });
69
+ expect(result.data).toHaveLength(2);
70
+ expect(result.data.every((e) => e.payload.query.startsWith('SELECT'))).toBe(true);
71
+ });
72
+ });
73
+ describe('sources', () => {
74
+ it('filters queries by ORM source', async () => {
75
+ const entries = [
76
+ (0, entry_factories_1.createQueryEntry)({ source: 'typeorm' }),
77
+ (0, entry_factories_1.createQueryEntry)({ source: 'prisma' }),
78
+ (0, entry_factories_1.createQueryEntry)({ source: 'typeorm' }),
79
+ ];
80
+ await (0, test_utils_1.seedStorage)(storage, entries);
81
+ const result = await storage.findWithCursor('query', {
82
+ filters: { sources: ['typeorm'] },
83
+ });
84
+ expect(result.data).toHaveLength(2);
85
+ });
86
+ });
87
+ describe('slow', () => {
88
+ it('filters slow queries', async () => {
89
+ const entries = [
90
+ (0, entry_factories_1.createQueryEntry)({ slow: true }),
91
+ (0, entry_factories_1.createQueryEntry)({ slow: false }),
92
+ (0, entry_factories_1.createQueryEntry)({ slow: true }),
93
+ ];
94
+ await (0, test_utils_1.seedStorage)(storage, entries);
95
+ const result = await storage.findWithCursor('query', {
96
+ filters: { slow: true },
97
+ });
98
+ expect(result.data).toHaveLength(2);
99
+ expect(result.data.every((e) => e.payload.slow === true)).toBe(true);
100
+ });
101
+ });
102
+ });
103
+ // ==================== EXCEPTION FILTERS ====================
104
+ describe('Exception Filters', () => {
105
+ describe('names', () => {
106
+ it('filters exceptions by name with LIKE pattern', async () => {
107
+ const entries = [
108
+ (0, entry_factories_1.createExceptionEntry)({ name: 'TypeError' }),
109
+ (0, entry_factories_1.createExceptionEntry)({ name: 'TypeError: Cannot read property' }),
110
+ (0, entry_factories_1.createExceptionEntry)({ name: 'ReferenceError' }),
111
+ ];
112
+ await (0, test_utils_1.seedStorage)(storage, entries);
113
+ const result = await storage.findWithCursor('exception', {
114
+ filters: { names: ['TypeError'] },
115
+ });
116
+ expect(result.data).toHaveLength(2);
117
+ });
118
+ });
119
+ });
120
+ // ==================== REQUEST FILTERS ====================
121
+ describe('Request Filters', () => {
122
+ describe('methods', () => {
123
+ it('filters requests by HTTP method', async () => {
124
+ const entries = [
125
+ (0, entry_factories_1.createRequestEntry)({ method: 'GET' }),
126
+ (0, entry_factories_1.createRequestEntry)({ method: 'POST' }),
127
+ (0, entry_factories_1.createRequestEntry)({ method: 'DELETE' }),
128
+ ];
129
+ await (0, test_utils_1.seedStorage)(storage, entries);
130
+ const result = await storage.findWithCursor('request', {
131
+ filters: { methods: ['GET', 'POST'] },
132
+ });
133
+ expect(result.data).toHaveLength(2);
134
+ });
135
+ });
136
+ describe('paths', () => {
137
+ it('filters requests by path with LIKE pattern', async () => {
138
+ const entries = [
139
+ (0, entry_factories_1.createRequestEntry)({ path: '/api/users' }),
140
+ (0, entry_factories_1.createRequestEntry)({ path: '/api/users/1' }),
141
+ (0, entry_factories_1.createRequestEntry)({ path: '/api/orders' }),
142
+ ];
143
+ await (0, test_utils_1.seedStorage)(storage, entries);
144
+ const result = await storage.findWithCursor('request', {
145
+ filters: { paths: ['/api/users'] },
146
+ });
147
+ expect(result.data).toHaveLength(2);
148
+ });
149
+ });
150
+ describe('statuses', () => {
151
+ it('filters requests by status code', async () => {
152
+ const entries = [
153
+ (0, entry_factories_1.createRequestEntry)({ statusCode: 200 }),
154
+ (0, entry_factories_1.createRequestEntry)({ statusCode: 201 }),
155
+ (0, entry_factories_1.createRequestEntry)({ statusCode: 404 }),
156
+ ];
157
+ await (0, test_utils_1.seedStorage)(storage, entries);
158
+ const result = await storage.findWithCursor('request', {
159
+ filters: { statuses: [200, 201] },
160
+ });
161
+ expect(result.data).toHaveLength(2);
162
+ });
163
+ it('handles ERR status for entries without status code', async () => {
164
+ const entries = [
165
+ (0, entry_factories_1.createRequestEntry)({ statusCode: 200 }),
166
+ (0, entry_factories_1.createRequestEntry)({ statusCode: undefined }),
167
+ ];
168
+ await (0, test_utils_1.seedStorage)(storage, entries);
169
+ const result = await storage.findWithCursor('request', {
170
+ filters: { statuses: ['ERR'] },
171
+ });
172
+ expect(result.data).toHaveLength(1);
173
+ });
174
+ });
175
+ describe('hostnames', () => {
176
+ it('filters requests by hostname', async () => {
177
+ const entries = [
178
+ (0, entry_factories_1.createRequestEntry)({ headers: { host: 'localhost:3000' } }),
179
+ (0, entry_factories_1.createRequestEntry)({ headers: { host: 'api.example.com' } }),
180
+ ];
181
+ await (0, test_utils_1.seedStorage)(storage, entries);
182
+ const result = await storage.findWithCursor('request', {
183
+ filters: { hostnames: ['localhost'] },
184
+ });
185
+ expect(result.data).toHaveLength(1);
186
+ });
187
+ });
188
+ describe('controllers', () => {
189
+ it('filters requests by controller action', async () => {
190
+ const entries = [
191
+ (0, entry_factories_1.createRequestEntry)({ controllerAction: 'UsersController#findAll' }),
192
+ (0, entry_factories_1.createRequestEntry)({ controllerAction: 'UsersController#create' }),
193
+ (0, entry_factories_1.createRequestEntry)({ controllerAction: 'OrdersController#list' }),
194
+ ];
195
+ await (0, test_utils_1.seedStorage)(storage, entries);
196
+ const result = await storage.findWithCursor('request', {
197
+ filters: { controllers: ['UsersController#findAll', 'UsersController#create'] },
198
+ });
199
+ expect(result.data).toHaveLength(2);
200
+ });
201
+ });
202
+ describe('ips', () => {
203
+ it('filters requests by IP address', async () => {
204
+ const entries = [
205
+ (0, entry_factories_1.createRequestEntry)({ ip: '127.0.0.1' }),
206
+ (0, entry_factories_1.createRequestEntry)({ ip: '::1' }),
207
+ (0, entry_factories_1.createRequestEntry)({ ip: '192.168.1.1' }),
208
+ ];
209
+ await (0, test_utils_1.seedStorage)(storage, entries);
210
+ const result = await storage.findWithCursor('request', {
211
+ filters: { ips: ['127.0.0.1', '::1'] },
212
+ });
213
+ expect(result.data).toHaveLength(2);
214
+ });
215
+ });
216
+ });
217
+ // ==================== HTTP CLIENT FILTERS ====================
218
+ describe('HTTP Client Filters', () => {
219
+ describe('methods', () => {
220
+ it('filters http client entries by method', async () => {
221
+ const entries = [
222
+ (0, entry_factories_1.createHttpClientEntry)({ method: 'GET' }),
223
+ (0, entry_factories_1.createHttpClientEntry)({ method: 'POST' }),
224
+ (0, entry_factories_1.createHttpClientEntry)({ method: 'DELETE' }),
225
+ ];
226
+ await (0, test_utils_1.seedStorage)(storage, entries);
227
+ const result = await storage.findWithCursor('http-client', {
228
+ filters: { methods: ['GET', 'POST'] },
229
+ });
230
+ expect(result.data).toHaveLength(2);
231
+ });
232
+ });
233
+ describe('statuses', () => {
234
+ it('filters http client entries by status code', async () => {
235
+ const entries = [
236
+ (0, entry_factories_1.createHttpClientEntry)({ statusCode: 200 }),
237
+ (0, entry_factories_1.createHttpClientEntry)({ statusCode: 404 }),
238
+ (0, entry_factories_1.createHttpClientEntry)({ statusCode: 500 }),
239
+ ];
240
+ await (0, test_utils_1.seedStorage)(storage, entries);
241
+ const result = await storage.findWithCursor('http-client', {
242
+ filters: { statuses: [200, 404] },
243
+ });
244
+ expect(result.data).toHaveLength(2);
245
+ });
246
+ });
247
+ describe('hostnames', () => {
248
+ it('filters http client entries by hostname', async () => {
249
+ const entries = [
250
+ (0, entry_factories_1.createHttpClientEntry)({ hostname: 'api.example.com' }),
251
+ (0, entry_factories_1.createHttpClientEntry)({ hostname: 'cdn.example.com' }),
252
+ (0, entry_factories_1.createHttpClientEntry)({ hostname: 'auth.different.com' }),
253
+ ];
254
+ await (0, test_utils_1.seedStorage)(storage, entries);
255
+ const result = await storage.findWithCursor('http-client', {
256
+ filters: { hostnames: ['example'] },
257
+ });
258
+ expect(result.data).toHaveLength(2);
259
+ });
260
+ });
261
+ });
262
+ // ==================== EVENT FILTERS ====================
263
+ describe('Event Filters', () => {
264
+ describe('names', () => {
265
+ it('filters events by name with LIKE pattern', async () => {
266
+ const entries = [
267
+ (0, entry_factories_1.createEventEntry)({ name: 'user.created' }),
268
+ (0, entry_factories_1.createEventEntry)({ name: 'user.updated' }),
269
+ (0, entry_factories_1.createEventEntry)({ name: 'order.placed' }),
270
+ ];
271
+ await (0, test_utils_1.seedStorage)(storage, entries);
272
+ const result = await storage.findWithCursor('event', {
273
+ filters: { names: ['user'] },
274
+ });
275
+ expect(result.data).toHaveLength(2);
276
+ });
277
+ });
278
+ });
279
+ // ==================== JOB FILTERS ====================
280
+ describe('Job Filters', () => {
281
+ describe('jobStatuses', () => {
282
+ it('filters jobs by status', async () => {
283
+ const entries = [
284
+ (0, entry_factories_1.createJobEntry)({ status: 'completed' }),
285
+ (0, entry_factories_1.createJobEntry)({ status: 'active' }),
286
+ (0, entry_factories_1.createJobEntry)({ status: 'failed' }),
287
+ ];
288
+ await (0, test_utils_1.seedStorage)(storage, entries);
289
+ const result = await storage.findWithCursor('job', {
290
+ filters: { jobStatuses: ['completed', 'active'] },
291
+ });
292
+ expect(result.data).toHaveLength(2);
293
+ });
294
+ });
295
+ describe('queues', () => {
296
+ it('filters jobs by queue name', async () => {
297
+ const entries = [
298
+ (0, entry_factories_1.createJobEntry)({ queue: 'default' }),
299
+ (0, entry_factories_1.createJobEntry)({ queue: 'emails' }),
300
+ (0, entry_factories_1.createJobEntry)({ queue: 'notifications' }),
301
+ ];
302
+ await (0, test_utils_1.seedStorage)(storage, entries);
303
+ const result = await storage.findWithCursor('job', {
304
+ filters: { queues: ['default', 'emails'] },
305
+ });
306
+ expect(result.data).toHaveLength(2);
307
+ });
308
+ });
309
+ describe('names', () => {
310
+ it('filters jobs by name with LIKE pattern', async () => {
311
+ const entries = [
312
+ (0, entry_factories_1.createJobEntry)({ name: 'send-email' }),
313
+ (0, entry_factories_1.createJobEntry)({ name: 'send-notification' }),
314
+ (0, entry_factories_1.createJobEntry)({ name: 'process-order' }),
315
+ ];
316
+ await (0, test_utils_1.seedStorage)(storage, entries);
317
+ const result = await storage.findWithCursor('job', {
318
+ filters: { names: ['send'] },
319
+ });
320
+ expect(result.data).toHaveLength(2);
321
+ });
322
+ });
323
+ });
324
+ // ==================== SCHEDULE FILTERS ====================
325
+ describe('Schedule Filters', () => {
326
+ describe('scheduleStatuses', () => {
327
+ it('filters scheduled tasks by status', async () => {
328
+ const entries = [
329
+ (0, entry_factories_1.createScheduleEntry)({ status: 'completed' }),
330
+ (0, entry_factories_1.createScheduleEntry)({ status: 'started' }),
331
+ (0, entry_factories_1.createScheduleEntry)({ status: 'failed' }),
332
+ ];
333
+ await (0, test_utils_1.seedStorage)(storage, entries);
334
+ const result = await storage.findWithCursor('schedule', {
335
+ filters: { scheduleStatuses: ['completed'] },
336
+ });
337
+ expect(result.data).toHaveLength(1);
338
+ });
339
+ });
340
+ describe('names', () => {
341
+ it('filters scheduled tasks by name with LIKE pattern', async () => {
342
+ const entries = [
343
+ (0, entry_factories_1.createScheduleEntry)({ name: 'cleanup-task' }),
344
+ (0, entry_factories_1.createScheduleEntry)({ name: 'cleanup-logs' }),
345
+ (0, entry_factories_1.createScheduleEntry)({ name: 'send-reports' }),
346
+ ];
347
+ await (0, test_utils_1.seedStorage)(storage, entries);
348
+ const result = await storage.findWithCursor('schedule', {
349
+ filters: { names: ['cleanup'] },
350
+ });
351
+ expect(result.data).toHaveLength(2);
352
+ });
353
+ });
354
+ });
355
+ // ==================== CACHE FILTERS ====================
356
+ describe('Cache Filters', () => {
357
+ describe('cacheOperations', () => {
358
+ it('filters cache entries by operation', async () => {
359
+ const entries = [
360
+ (0, entry_factories_1.createCacheEntry)({ operation: 'get' }),
361
+ (0, entry_factories_1.createCacheEntry)({ operation: 'set' }),
362
+ (0, entry_factories_1.createCacheEntry)({ operation: 'del' }),
363
+ ];
364
+ await (0, test_utils_1.seedStorage)(storage, entries);
365
+ const result = await storage.findWithCursor('cache', {
366
+ filters: { cacheOperations: ['get', 'set'] },
367
+ });
368
+ expect(result.data).toHaveLength(2);
369
+ });
370
+ });
371
+ });
372
+ // ==================== MAIL FILTERS ====================
373
+ describe('Mail Filters', () => {
374
+ describe('mailStatuses', () => {
375
+ it('filters mail entries by status', async () => {
376
+ const entries = [
377
+ (0, entry_factories_1.createMailEntry)({ status: 'sent' }),
378
+ (0, entry_factories_1.createMailEntry)({ status: 'failed' }),
379
+ (0, entry_factories_1.createMailEntry)({ status: 'sent' }),
380
+ ];
381
+ await (0, test_utils_1.seedStorage)(storage, entries);
382
+ const result = await storage.findWithCursor('mail', {
383
+ filters: { mailStatuses: ['sent'] },
384
+ });
385
+ expect(result.data).toHaveLength(2);
386
+ });
387
+ });
388
+ });
389
+ // ==================== REDIS FILTERS ====================
390
+ describe('Redis Filters', () => {
391
+ describe('redisStatuses', () => {
392
+ it('filters redis entries by status', async () => {
393
+ const entries = [
394
+ (0, entry_factories_1.createRedisEntry)({ status: 'success' }),
395
+ (0, entry_factories_1.createRedisEntry)({ status: 'error' }),
396
+ (0, entry_factories_1.createRedisEntry)({ status: 'success' }),
397
+ ];
398
+ await (0, test_utils_1.seedStorage)(storage, entries);
399
+ const result = await storage.findWithCursor('redis', {
400
+ filters: { redisStatuses: ['success'] },
401
+ });
402
+ expect(result.data).toHaveLength(2);
403
+ });
404
+ });
405
+ describe('redisCommands', () => {
406
+ it('filters redis entries by command', async () => {
407
+ const entries = [
408
+ (0, entry_factories_1.createRedisEntry)({ command: 'GET' }),
409
+ (0, entry_factories_1.createRedisEntry)({ command: 'SET' }),
410
+ (0, entry_factories_1.createRedisEntry)({ command: 'HGET' }),
411
+ ];
412
+ await (0, test_utils_1.seedStorage)(storage, entries);
413
+ const result = await storage.findWithCursor('redis', {
414
+ filters: { redisCommands: ['GET', 'SET'] },
415
+ });
416
+ expect(result.data).toHaveLength(2);
417
+ });
418
+ });
419
+ });
420
+ // ==================== MODEL FILTERS ====================
421
+ describe('Model Filters', () => {
422
+ describe('modelActions', () => {
423
+ it('filters model entries by action', async () => {
424
+ const entries = [
425
+ (0, entry_factories_1.createModelEntry)({ action: 'create' }),
426
+ (0, entry_factories_1.createModelEntry)({ action: 'update' }),
427
+ (0, entry_factories_1.createModelEntry)({ action: 'find' }),
428
+ ];
429
+ await (0, test_utils_1.seedStorage)(storage, entries);
430
+ const result = await storage.findWithCursor('model', {
431
+ filters: { modelActions: ['create', 'update'] },
432
+ });
433
+ expect(result.data).toHaveLength(2);
434
+ });
435
+ });
436
+ describe('entities', () => {
437
+ it('filters model entries by entity name', async () => {
438
+ const entries = [
439
+ (0, entry_factories_1.createModelEntry)({ entity: 'User' }),
440
+ (0, entry_factories_1.createModelEntry)({ entity: 'Post' }),
441
+ (0, entry_factories_1.createModelEntry)({ entity: 'Comment' }),
442
+ ];
443
+ await (0, test_utils_1.seedStorage)(storage, entries);
444
+ const result = await storage.findWithCursor('model', {
445
+ filters: { entities: ['User', 'Post'] },
446
+ });
447
+ expect(result.data).toHaveLength(2);
448
+ });
449
+ });
450
+ describe('modelSources', () => {
451
+ it('filters model entries by ORM source', async () => {
452
+ const entries = [
453
+ (0, entry_factories_1.createModelEntry)({ source: 'typeorm' }),
454
+ (0, entry_factories_1.createModelEntry)({ source: 'prisma' }),
455
+ (0, entry_factories_1.createModelEntry)({ source: 'typeorm' }),
456
+ ];
457
+ await (0, test_utils_1.seedStorage)(storage, entries);
458
+ const result = await storage.findWithCursor('model', {
459
+ filters: { modelSources: ['typeorm'] },
460
+ });
461
+ expect(result.data).toHaveLength(2);
462
+ });
463
+ });
464
+ });
465
+ // ==================== NOTIFICATION FILTERS ====================
466
+ describe('Notification Filters', () => {
467
+ describe('notificationTypes', () => {
468
+ it('filters notifications by type', async () => {
469
+ const entries = [
470
+ (0, entry_factories_1.createNotificationEntry)({ type: 'email' }),
471
+ (0, entry_factories_1.createNotificationEntry)({ type: 'sms' }),
472
+ (0, entry_factories_1.createNotificationEntry)({ type: 'push' }),
473
+ ];
474
+ await (0, test_utils_1.seedStorage)(storage, entries);
475
+ const result = await storage.findWithCursor('notification', {
476
+ filters: { notificationTypes: ['email', 'sms'] },
477
+ });
478
+ expect(result.data).toHaveLength(2);
479
+ });
480
+ });
481
+ describe('notificationStatuses', () => {
482
+ it('filters notifications by status', async () => {
483
+ const entries = [
484
+ (0, entry_factories_1.createNotificationEntry)({ status: 'sent' }),
485
+ (0, entry_factories_1.createNotificationEntry)({ status: 'failed' }),
486
+ (0, entry_factories_1.createNotificationEntry)({ status: 'sent' }),
487
+ ];
488
+ await (0, test_utils_1.seedStorage)(storage, entries);
489
+ const result = await storage.findWithCursor('notification', {
490
+ filters: { notificationStatuses: ['sent'] },
491
+ });
492
+ expect(result.data).toHaveLength(2);
493
+ });
494
+ });
495
+ });
496
+ // ==================== VIEW FILTERS ====================
497
+ describe('View Filters', () => {
498
+ describe('viewFormats', () => {
499
+ it('filters views by format', async () => {
500
+ const entries = [
501
+ (0, entry_factories_1.createViewEntry)({ format: 'html' }),
502
+ (0, entry_factories_1.createViewEntry)({ format: 'json' }),
503
+ (0, entry_factories_1.createViewEntry)({ format: 'xml' }),
504
+ ];
505
+ await (0, test_utils_1.seedStorage)(storage, entries);
506
+ const result = await storage.findWithCursor('view', {
507
+ filters: { viewFormats: ['html', 'json'] },
508
+ });
509
+ expect(result.data).toHaveLength(2);
510
+ });
511
+ });
512
+ describe('viewStatuses', () => {
513
+ it('filters views by status', async () => {
514
+ const entries = [
515
+ (0, entry_factories_1.createViewEntry)({ status: 'rendered' }),
516
+ (0, entry_factories_1.createViewEntry)({ status: 'error' }),
517
+ (0, entry_factories_1.createViewEntry)({ status: 'rendered' }),
518
+ ];
519
+ await (0, test_utils_1.seedStorage)(storage, entries);
520
+ const result = await storage.findWithCursor('view', {
521
+ filters: { viewStatuses: ['rendered'] },
522
+ });
523
+ expect(result.data).toHaveLength(2);
524
+ });
525
+ });
526
+ });
527
+ // ==================== COMMAND FILTERS ====================
528
+ describe('Command Filters', () => {
529
+ describe('commandStatuses', () => {
530
+ it('filters commands by status', async () => {
531
+ const entries = [
532
+ (0, entry_factories_1.createCommandEntry)({ status: 'completed' }),
533
+ (0, entry_factories_1.createCommandEntry)({ status: 'executing' }),
534
+ (0, entry_factories_1.createCommandEntry)({ status: 'failed' }),
535
+ ];
536
+ await (0, test_utils_1.seedStorage)(storage, entries);
537
+ const result = await storage.findWithCursor('command', {
538
+ filters: { commandStatuses: ['completed'] },
539
+ });
540
+ expect(result.data).toHaveLength(1);
541
+ });
542
+ });
543
+ describe('commandNames', () => {
544
+ it('filters commands by name with LIKE pattern', async () => {
545
+ const entries = [
546
+ (0, entry_factories_1.createCommandEntry)({ name: 'cache:clear' }),
547
+ (0, entry_factories_1.createCommandEntry)({ name: 'cache:warmup' }),
548
+ (0, entry_factories_1.createCommandEntry)({ name: 'db:migrate' }),
549
+ ];
550
+ await (0, test_utils_1.seedStorage)(storage, entries);
551
+ const result = await storage.findWithCursor('command', {
552
+ filters: { commandNames: ['cache'] },
553
+ });
554
+ expect(result.data).toHaveLength(2);
555
+ });
556
+ });
557
+ });
558
+ // ==================== GATE FILTERS ====================
559
+ describe('Gate Filters', () => {
560
+ describe('gateNames', () => {
561
+ it('filters gates by name with LIKE pattern', async () => {
562
+ const entries = [
563
+ (0, entry_factories_1.createGateEntry)({ gate: 'admin' }),
564
+ (0, entry_factories_1.createGateEntry)({ gate: 'admin-panel' }),
565
+ (0, entry_factories_1.createGateEntry)({ gate: 'premium' }),
566
+ ];
567
+ await (0, test_utils_1.seedStorage)(storage, entries);
568
+ const result = await storage.findWithCursor('gate', {
569
+ filters: { gateNames: ['admin'] },
570
+ });
571
+ expect(result.data).toHaveLength(2);
572
+ });
573
+ });
574
+ describe('gateResults', () => {
575
+ it('filters gates by result (allowed)', async () => {
576
+ const entries = [
577
+ (0, entry_factories_1.createGateEntry)({ allowed: true }),
578
+ (0, entry_factories_1.createGateEntry)({ allowed: false }),
579
+ (0, entry_factories_1.createGateEntry)({ allowed: true }),
580
+ ];
581
+ await (0, test_utils_1.seedStorage)(storage, entries);
582
+ const result = await storage.findWithCursor('gate', {
583
+ filters: { gateResults: ['allowed'] },
584
+ });
585
+ expect(result.data).toHaveLength(2);
586
+ });
587
+ it('filters gates by result (denied)', async () => {
588
+ const entries = [
589
+ (0, entry_factories_1.createGateEntry)({ allowed: true }),
590
+ (0, entry_factories_1.createGateEntry)({ allowed: false }),
591
+ (0, entry_factories_1.createGateEntry)({ allowed: false }),
592
+ ];
593
+ await (0, test_utils_1.seedStorage)(storage, entries);
594
+ const result = await storage.findWithCursor('gate', {
595
+ filters: { gateResults: ['denied'] },
596
+ });
597
+ expect(result.data).toHaveLength(2);
598
+ });
599
+ });
600
+ });
601
+ // ==================== BATCH FILTERS ====================
602
+ describe('Batch Filters', () => {
603
+ describe('batchStatuses', () => {
604
+ it('filters batches by status', async () => {
605
+ const entries = [
606
+ (0, entry_factories_1.createBatchEntry)({ status: 'completed' }),
607
+ (0, entry_factories_1.createBatchEntry)({ status: 'partial' }),
608
+ (0, entry_factories_1.createBatchEntry)({ status: 'failed' }),
609
+ ];
610
+ await (0, test_utils_1.seedStorage)(storage, entries);
611
+ const result = await storage.findWithCursor('batch', {
612
+ filters: { batchStatuses: ['completed'] },
613
+ });
614
+ expect(result.data).toHaveLength(1);
615
+ });
616
+ });
617
+ describe('batchOperations', () => {
618
+ it('filters batches by operation', async () => {
619
+ const entries = [
620
+ (0, entry_factories_1.createBatchEntry)({ operation: 'insert' }),
621
+ (0, entry_factories_1.createBatchEntry)({ operation: 'update' }),
622
+ (0, entry_factories_1.createBatchEntry)({ operation: 'delete' }),
623
+ ];
624
+ await (0, test_utils_1.seedStorage)(storage, entries);
625
+ const result = await storage.findWithCursor('batch', {
626
+ filters: { batchOperations: ['insert', 'update'] },
627
+ });
628
+ expect(result.data).toHaveLength(2);
629
+ });
630
+ });
631
+ });
632
+ // ==================== DUMP FILTERS ====================
633
+ describe('Dump Filters', () => {
634
+ describe('dumpStatuses', () => {
635
+ it('filters dumps by status', async () => {
636
+ const entries = [
637
+ (0, entry_factories_1.createDumpEntry)({ status: 'completed' }),
638
+ (0, entry_factories_1.createDumpEntry)({ status: 'failed' }),
639
+ (0, entry_factories_1.createDumpEntry)({ status: 'completed' }),
640
+ ];
641
+ await (0, test_utils_1.seedStorage)(storage, entries);
642
+ const result = await storage.findWithCursor('dump', {
643
+ filters: { dumpStatuses: ['completed'] },
644
+ });
645
+ expect(result.data).toHaveLength(2);
646
+ });
647
+ });
648
+ describe('dumpOperations', () => {
649
+ it('filters dumps by operation', async () => {
650
+ const entries = [
651
+ (0, entry_factories_1.createDumpEntry)({ operation: 'export' }),
652
+ (0, entry_factories_1.createDumpEntry)({ operation: 'backup' }),
653
+ (0, entry_factories_1.createDumpEntry)({ operation: 'import' }),
654
+ ];
655
+ await (0, test_utils_1.seedStorage)(storage, entries);
656
+ const result = await storage.findWithCursor('dump', {
657
+ filters: { dumpOperations: ['export', 'backup'] },
658
+ });
659
+ expect(result.data).toHaveLength(2);
660
+ });
661
+ });
662
+ describe('dumpFormats', () => {
663
+ it('filters dumps by format', async () => {
664
+ const entries = [
665
+ (0, entry_factories_1.createDumpEntry)({ format: 'json' }),
666
+ (0, entry_factories_1.createDumpEntry)({ format: 'sql' }),
667
+ (0, entry_factories_1.createDumpEntry)({ format: 'csv' }),
668
+ ];
669
+ await (0, test_utils_1.seedStorage)(storage, entries);
670
+ const result = await storage.findWithCursor('dump', {
671
+ filters: { dumpFormats: ['json', 'sql'] },
672
+ });
673
+ expect(result.data).toHaveLength(2);
674
+ });
675
+ });
676
+ });
677
+ // ==================== COMBINED FILTER TESTS ====================
678
+ describe('Combined Filters (AND logic)', () => {
679
+ it('applies AND logic between multiple filters', async () => {
680
+ const entries = [
681
+ (0, entry_factories_1.createLogEntry)({ level: 'error', context: 'UserService' }),
682
+ (0, entry_factories_1.createLogEntry)({ level: 'error', context: 'AuthController' }),
683
+ (0, entry_factories_1.createLogEntry)({ level: 'warn', context: 'UserService' }),
684
+ (0, entry_factories_1.createLogEntry)({ level: 'debug', context: 'CacheModule' }),
685
+ ];
686
+ await (0, test_utils_1.seedStorage)(storage, entries);
687
+ const result = await storage.findWithCursor('log', {
688
+ filters: {
689
+ levels: ['error'],
690
+ contexts: ['UserService'],
691
+ },
692
+ });
693
+ expect(result.data).toHaveLength(1);
694
+ expect(result.data[0].payload.level).toBe('error');
695
+ expect(result.data[0].payload.context).toBe('UserService');
696
+ });
697
+ });
698
+ });
699
+ //# sourceMappingURL=storage-filters.spec.js.map