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.
- package/LICENSE +21 -0
- package/README.md +145 -0
- package/dist/__tests__/api/api.controller.spec.d.ts +2 -0
- package/dist/__tests__/api/api.controller.spec.d.ts.map +1 -0
- package/dist/__tests__/api/api.controller.spec.js +982 -0
- package/dist/__tests__/api/api.controller.spec.js.map +1 -0
- package/dist/__tests__/api/api.guard.spec.d.ts +2 -0
- package/dist/__tests__/api/api.guard.spec.d.ts.map +1 -0
- package/dist/__tests__/api/api.guard.spec.js +572 -0
- package/dist/__tests__/api/api.guard.spec.js.map +1 -0
- package/dist/__tests__/api/dashboard.controller.spec.d.ts +2 -0
- package/dist/__tests__/api/dashboard.controller.spec.d.ts.map +1 -0
- package/dist/__tests__/api/dashboard.controller.spec.js +474 -0
- package/dist/__tests__/api/dashboard.controller.spec.js.map +1 -0
- package/dist/__tests__/api/tag.controller.spec.d.ts +2 -0
- package/dist/__tests__/api/tag.controller.spec.d.ts.map +1 -0
- package/dist/__tests__/api/tag.controller.spec.js +280 -0
- package/dist/__tests__/api/tag.controller.spec.js.map +1 -0
- package/dist/__tests__/collector.service.spec.d.ts +2 -0
- package/dist/__tests__/collector.service.spec.d.ts.map +1 -0
- package/dist/__tests__/collector.service.spec.js +240 -0
- package/dist/__tests__/collector.service.spec.js.map +1 -0
- package/dist/__tests__/core/collector.service.spec.d.ts +2 -0
- package/dist/__tests__/core/collector.service.spec.d.ts.map +1 -0
- package/dist/__tests__/core/collector.service.spec.js +526 -0
- package/dist/__tests__/core/collector.service.spec.js.map +1 -0
- package/dist/__tests__/core/family-hash.service.spec.d.ts +2 -0
- package/dist/__tests__/core/family-hash.service.spec.d.ts.map +1 -0
- package/dist/__tests__/core/family-hash.service.spec.js +1117 -0
- package/dist/__tests__/core/family-hash.service.spec.js.map +1 -0
- package/dist/__tests__/core/pruning.service.spec.d.ts +2 -0
- package/dist/__tests__/core/pruning.service.spec.d.ts.map +1 -0
- package/dist/__tests__/core/pruning.service.spec.js +224 -0
- package/dist/__tests__/core/pruning.service.spec.js.map +1 -0
- package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts +2 -0
- package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts.map +1 -0
- package/dist/__tests__/core/storage/sqlite.storage.spec.js +853 -0
- package/dist/__tests__/core/storage/sqlite.storage.spec.js.map +1 -0
- package/dist/__tests__/core/tag.service.spec.d.ts +2 -0
- package/dist/__tests__/core/tag.service.spec.d.ts.map +1 -0
- package/dist/__tests__/core/tag.service.spec.js +994 -0
- package/dist/__tests__/core/tag.service.spec.js.map +1 -0
- package/dist/__tests__/family-hash.service.spec.d.ts +2 -0
- package/dist/__tests__/family-hash.service.spec.d.ts.map +1 -0
- package/dist/__tests__/family-hash.service.spec.js +325 -0
- package/dist/__tests__/family-hash.service.spec.js.map +1 -0
- package/dist/__tests__/filters/api-filters.spec.d.ts +2 -0
- package/dist/__tests__/filters/api-filters.spec.d.ts.map +1 -0
- package/dist/__tests__/filters/api-filters.spec.js +172 -0
- package/dist/__tests__/filters/api-filters.spec.js.map +1 -0
- package/dist/__tests__/filters/entry-factories.d.ts +20 -0
- package/dist/__tests__/filters/entry-factories.d.ts.map +1 -0
- package/dist/__tests__/filters/entry-factories.js +288 -0
- package/dist/__tests__/filters/entry-factories.js.map +1 -0
- package/dist/__tests__/filters/filter-contract.spec.d.ts +2 -0
- package/dist/__tests__/filters/filter-contract.spec.d.ts.map +1 -0
- package/dist/__tests__/filters/filter-contract.spec.js +230 -0
- package/dist/__tests__/filters/filter-contract.spec.js.map +1 -0
- package/dist/__tests__/filters/filter-test-data.d.ts +26 -0
- package/dist/__tests__/filters/filter-test-data.d.ts.map +1 -0
- package/dist/__tests__/filters/filter-test-data.js +374 -0
- package/dist/__tests__/filters/filter-test-data.js.map +1 -0
- package/dist/__tests__/filters/storage-filters.spec.d.ts +2 -0
- package/dist/__tests__/filters/storage-filters.spec.d.ts.map +1 -0
- package/dist/__tests__/filters/storage-filters.spec.js +699 -0
- package/dist/__tests__/filters/storage-filters.spec.js.map +1 -0
- package/dist/__tests__/filters/test-utils.d.ts +23 -0
- package/dist/__tests__/filters/test-utils.d.ts.map +1 -0
- package/dist/__tests__/filters/test-utils.js +54 -0
- package/dist/__tests__/filters/test-utils.js.map +1 -0
- package/dist/__tests__/nestlens.module.spec.d.ts +2 -0
- package/dist/__tests__/nestlens.module.spec.d.ts.map +1 -0
- package/dist/__tests__/nestlens.module.spec.js +620 -0
- package/dist/__tests__/nestlens.module.spec.js.map +1 -0
- package/dist/__tests__/pruning.service.spec.d.ts +2 -0
- package/dist/__tests__/pruning.service.spec.d.ts.map +1 -0
- package/dist/__tests__/pruning.service.spec.js +142 -0
- package/dist/__tests__/pruning.service.spec.js.map +1 -0
- package/dist/__tests__/setup.d.ts +7 -0
- package/dist/__tests__/setup.d.ts.map +1 -0
- package/dist/__tests__/setup.js +24 -0
- package/dist/__tests__/setup.js.map +1 -0
- package/dist/__tests__/tag.service.spec.d.ts +2 -0
- package/dist/__tests__/tag.service.spec.d.ts.map +1 -0
- package/dist/__tests__/tag.service.spec.js +482 -0
- package/dist/__tests__/tag.service.spec.js.map +1 -0
- package/dist/__tests__/watchers/batch.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/batch.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/batch.watcher.spec.js +515 -0
- package/dist/__tests__/watchers/batch.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/cache.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/cache.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/cache.watcher.spec.js +395 -0
- package/dist/__tests__/watchers/cache.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/command.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/command.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/command.watcher.spec.js +598 -0
- package/dist/__tests__/watchers/command.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/dump.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/dump.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/dump.watcher.spec.js +724 -0
- package/dist/__tests__/watchers/dump.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/event.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/event.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/event.watcher.spec.js +316 -0
- package/dist/__tests__/watchers/event.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/exception.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/exception.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/exception.watcher.spec.js +495 -0
- package/dist/__tests__/watchers/exception.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/gate.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/gate.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/gate.watcher.spec.js +683 -0
- package/dist/__tests__/watchers/gate.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/http-client.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/http-client.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/http-client.watcher.spec.js +888 -0
- package/dist/__tests__/watchers/http-client.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/job.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/job.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/job.watcher.spec.js +513 -0
- package/dist/__tests__/watchers/job.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/log.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/log.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/log.watcher.spec.js +428 -0
- package/dist/__tests__/watchers/log.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/mail.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/mail.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/mail.watcher.spec.js +425 -0
- package/dist/__tests__/watchers/mail.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/model.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/model.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/model.watcher.spec.js +675 -0
- package/dist/__tests__/watchers/model.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/notification.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/notification.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/notification.watcher.spec.js +595 -0
- package/dist/__tests__/watchers/notification.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/query/types.spec.d.ts +2 -0
- package/dist/__tests__/watchers/query/types.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/query/types.spec.js +292 -0
- package/dist/__tests__/watchers/query/types.spec.js.map +1 -0
- package/dist/__tests__/watchers/query.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/query.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/query.watcher.spec.js +597 -0
- package/dist/__tests__/watchers/query.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/redis.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/redis.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/redis.watcher.spec.js +634 -0
- package/dist/__tests__/watchers/redis.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/request.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/request.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/request.watcher.spec.js +1017 -0
- package/dist/__tests__/watchers/request.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/schedule.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/schedule.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/schedule.watcher.spec.js +338 -0
- package/dist/__tests__/watchers/schedule.watcher.spec.js.map +1 -0
- package/dist/__tests__/watchers/view.watcher.spec.d.ts +2 -0
- package/dist/__tests__/watchers/view.watcher.spec.d.ts.map +1 -0
- package/dist/__tests__/watchers/view.watcher.spec.js +564 -0
- package/dist/__tests__/watchers/view.watcher.spec.js.map +1 -0
- package/dist/api/api.controller.d.ts +193 -0
- package/dist/api/api.controller.d.ts.map +1 -0
- package/dist/api/api.controller.js +562 -0
- package/dist/api/api.controller.js.map +1 -0
- package/dist/api/api.guard.d.ts +77 -0
- package/dist/api/api.guard.d.ts.map +1 -0
- package/dist/api/api.guard.js +294 -0
- package/dist/api/api.guard.js.map +1 -0
- package/dist/api/dashboard.controller.d.ts +49 -0
- package/dist/api/dashboard.controller.d.ts.map +1 -0
- package/dist/api/dashboard.controller.js +472 -0
- package/dist/api/dashboard.controller.js.map +1 -0
- package/dist/api/index.d.ts +5 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +21 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/tag.controller.d.ts +65 -0
- package/dist/api/tag.controller.d.ts.map +1 -0
- package/dist/api/tag.controller.js +149 -0
- package/dist/api/tag.controller.js.map +1 -0
- package/dist/core/collector.service.d.ts +80 -0
- package/dist/core/collector.service.d.ts.map +1 -0
- package/dist/core/collector.service.js +255 -0
- package/dist/core/collector.service.js.map +1 -0
- package/dist/core/family-hash.service.d.ts +64 -0
- package/dist/core/family-hash.service.d.ts.map +1 -0
- package/dist/core/family-hash.service.js +281 -0
- package/dist/core/family-hash.service.js.map +1 -0
- package/dist/core/index.d.ts +4 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +20 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/pruning.service.d.ts +16 -0
- package/dist/core/pruning.service.d.ts.map +1 -0
- package/dist/core/pruning.service.js +71 -0
- package/dist/core/pruning.service.js.map +1 -0
- package/dist/core/storage/index.d.ts +3 -0
- package/dist/core/storage/index.d.ts.map +1 -0
- package/dist/core/storage/index.js +19 -0
- package/dist/core/storage/index.js.map +1 -0
- package/dist/core/storage/sqlite.storage.d.ts +60 -0
- package/dist/core/storage/sqlite.storage.d.ts.map +1 -0
- package/dist/core/storage/sqlite.storage.js +929 -0
- package/dist/core/storage/sqlite.storage.js.map +1 -0
- package/dist/core/storage/storage.interface.d.ts +122 -0
- package/dist/core/storage/storage.interface.d.ts.map +1 -0
- package/dist/core/storage/storage.interface.js +5 -0
- package/dist/core/storage/storage.interface.js.map +1 -0
- package/dist/core/tag.service.d.ts +71 -0
- package/dist/core/tag.service.d.ts.map +1 -0
- package/dist/core/tag.service.js +568 -0
- package/dist/core/tag.service.js.map +1 -0
- package/dist/dashboard/public/assets/BatchesPage-DFT4fKlJ.js +1 -0
- package/dist/dashboard/public/assets/CachePage-CRy1Tjb8.js +1 -0
- package/dist/dashboard/public/assets/ClickableBadge-CV5J3THx.js +1 -0
- package/dist/dashboard/public/assets/CommandsPage-DdRnTm-W.js +1 -0
- package/dist/dashboard/public/assets/DashboardPage-CjaRZXYy.js +26 -0
- package/dist/dashboard/public/assets/DataTable-B6o9H8lh.js +88 -0
- package/dist/dashboard/public/assets/DumpsPage-DO8y1RTg.js +1 -0
- package/dist/dashboard/public/assets/EntryDetailPage-By-YcAGL.js +125 -0
- package/dist/dashboard/public/assets/EventsPage-u-r4AiT4.js +1 -0
- package/dist/dashboard/public/assets/ExceptionsPage-DXUcARr1.js +6 -0
- package/dist/dashboard/public/assets/GatesPage-DpeP7CDZ.js +1 -0
- package/dist/dashboard/public/assets/HttpClientPage-BJ4-5E6t.js +1 -0
- package/dist/dashboard/public/assets/JobsPage-Dv3KaX2x.js +1 -0
- package/dist/dashboard/public/assets/LogsPage-D0Q3yDb1.js +1 -0
- package/dist/dashboard/public/assets/MailPage-Bf8C6WF6.js +1 -0
- package/dist/dashboard/public/assets/ModelsPage-BMHncI5y.js +1 -0
- package/dist/dashboard/public/assets/NotificationsPage-D5-I-Oxb.js +1 -0
- package/dist/dashboard/public/assets/QueriesPage-oNp0i6Gt.js +1 -0
- package/dist/dashboard/public/assets/RedisPage-_GeS2OD8.js +1 -0
- package/dist/dashboard/public/assets/RequestsPage-BCwqu9US.js +1 -0
- package/dist/dashboard/public/assets/SchedulePage-CR0P-oX6.js +1 -0
- package/dist/dashboard/public/assets/ViewsPage-Dsy5ECRA.js +1 -0
- package/dist/dashboard/public/assets/calendar-DfK3x-6B.js +6 -0
- package/dist/dashboard/public/assets/circle-check-big-DcsYW8y8.js +6 -0
- package/dist/dashboard/public/assets/format-BFldcnCk.js +1 -0
- package/dist/dashboard/public/assets/index-DmeA1maE.css +1 -0
- package/dist/dashboard/public/assets/index-rkbGYdU7.js +351 -0
- package/dist/dashboard/public/assets/types-Cldoe2db.js +1 -0
- package/dist/dashboard/public/assets/vendor-B2nVRih0.js +43 -0
- package/dist/dashboard/public/assets/zap-DqtRi0JM.js +6 -0
- package/dist/dashboard/public/index.html +15 -0
- package/dist/dashboard/public/nestlens-icon.svg +9 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +69 -0
- package/dist/index.js.map +1 -0
- package/dist/nestlens.config.d.ts +216 -0
- package/dist/nestlens.config.d.ts.map +1 -0
- package/dist/nestlens.config.js +57 -0
- package/dist/nestlens.config.js.map +1 -0
- package/dist/nestlens.module.d.ts +10 -0
- package/dist/nestlens.module.d.ts.map +1 -0
- package/dist/nestlens.module.js +211 -0
- package/dist/nestlens.module.js.map +1 -0
- package/dist/types/entry.types.d.ts +368 -0
- package/dist/types/entry.types.d.ts.map +1 -0
- package/dist/types/entry.types.js +3 -0
- package/dist/types/entry.types.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +20 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/request.types.d.ts +9 -0
- package/dist/types/request.types.d.ts.map +1 -0
- package/dist/types/request.types.js +3 -0
- package/dist/types/request.types.js.map +1 -0
- package/dist/types/tag.types.d.ts +32 -0
- package/dist/types/tag.types.d.ts.map +1 -0
- package/dist/types/tag.types.js +3 -0
- package/dist/types/tag.types.js.map +1 -0
- package/dist/watchers/batch.watcher.d.ts +48 -0
- package/dist/watchers/batch.watcher.d.ts.map +1 -0
- package/dist/watchers/batch.watcher.js +185 -0
- package/dist/watchers/batch.watcher.js.map +1 -0
- package/dist/watchers/cache.watcher.d.ts +19 -0
- package/dist/watchers/cache.watcher.d.ts.map +1 -0
- package/dist/watchers/cache.watcher.js +158 -0
- package/dist/watchers/cache.watcher.js.map +1 -0
- package/dist/watchers/command.watcher.d.ts +32 -0
- package/dist/watchers/command.watcher.d.ts.map +1 -0
- package/dist/watchers/command.watcher.js +174 -0
- package/dist/watchers/command.watcher.js.map +1 -0
- package/dist/watchers/dump.watcher.d.ts +52 -0
- package/dist/watchers/dump.watcher.d.ts.map +1 -0
- package/dist/watchers/dump.watcher.js +234 -0
- package/dist/watchers/dump.watcher.js.map +1 -0
- package/dist/watchers/event.watcher.d.ts +20 -0
- package/dist/watchers/event.watcher.d.ts.map +1 -0
- package/dist/watchers/event.watcher.js +123 -0
- package/dist/watchers/event.watcher.js.map +1 -0
- package/dist/watchers/exception.watcher.d.ts +15 -0
- package/dist/watchers/exception.watcher.d.ts.map +1 -0
- package/dist/watchers/exception.watcher.js +117 -0
- package/dist/watchers/exception.watcher.js.map +1 -0
- package/dist/watchers/gate.watcher.d.ts +40 -0
- package/dist/watchers/gate.watcher.d.ts.map +1 -0
- package/dist/watchers/gate.watcher.js +200 -0
- package/dist/watchers/gate.watcher.js.map +1 -0
- package/dist/watchers/http-client.watcher.d.ts +34 -0
- package/dist/watchers/http-client.watcher.d.ts.map +1 -0
- package/dist/watchers/http-client.watcher.js +259 -0
- package/dist/watchers/http-client.watcher.js.map +1 -0
- package/dist/watchers/index.d.ts +19 -0
- package/dist/watchers/index.d.ts.map +1 -0
- package/dist/watchers/index.js +35 -0
- package/dist/watchers/index.js.map +1 -0
- package/dist/watchers/job.watcher.d.ts +27 -0
- package/dist/watchers/job.watcher.d.ts.map +1 -0
- package/dist/watchers/job.watcher.js +190 -0
- package/dist/watchers/job.watcher.js.map +1 -0
- package/dist/watchers/log.watcher.d.ts +26 -0
- package/dist/watchers/log.watcher.d.ts.map +1 -0
- package/dist/watchers/log.watcher.js +122 -0
- package/dist/watchers/log.watcher.js.map +1 -0
- package/dist/watchers/mail.watcher.d.ts +26 -0
- package/dist/watchers/mail.watcher.d.ts.map +1 -0
- package/dist/watchers/mail.watcher.js +154 -0
- package/dist/watchers/mail.watcher.js.map +1 -0
- package/dist/watchers/model.watcher.d.ts +54 -0
- package/dist/watchers/model.watcher.d.ts.map +1 -0
- package/dist/watchers/model.watcher.js +343 -0
- package/dist/watchers/model.watcher.js.map +1 -0
- package/dist/watchers/notification.watcher.d.ts +48 -0
- package/dist/watchers/notification.watcher.d.ts.map +1 -0
- package/dist/watchers/notification.watcher.js +215 -0
- package/dist/watchers/notification.watcher.js.map +1 -0
- package/dist/watchers/query/index.d.ts +3 -0
- package/dist/watchers/query/index.d.ts.map +1 -0
- package/dist/watchers/query/index.js +19 -0
- package/dist/watchers/query/index.js.map +1 -0
- package/dist/watchers/query/query.watcher.d.ts +27 -0
- package/dist/watchers/query/query.watcher.d.ts.map +1 -0
- package/dist/watchers/query/query.watcher.js +167 -0
- package/dist/watchers/query/query.watcher.js.map +1 -0
- package/dist/watchers/query/types.d.ts +60 -0
- package/dist/watchers/query/types.d.ts.map +1 -0
- package/dist/watchers/query/types.js +55 -0
- package/dist/watchers/query/types.js.map +1 -0
- package/dist/watchers/redis.watcher.d.ts +43 -0
- package/dist/watchers/redis.watcher.d.ts.map +1 -0
- package/dist/watchers/redis.watcher.js +225 -0
- package/dist/watchers/redis.watcher.js.map +1 -0
- package/dist/watchers/request.watcher.d.ts +21 -0
- package/dist/watchers/request.watcher.d.ts.map +1 -0
- package/dist/watchers/request.watcher.js +287 -0
- package/dist/watchers/request.watcher.js.map +1 -0
- package/dist/watchers/schedule.watcher.d.ts +25 -0
- package/dist/watchers/schedule.watcher.d.ts.map +1 -0
- package/dist/watchers/schedule.watcher.js +168 -0
- package/dist/watchers/schedule.watcher.js.map +1 -0
- package/dist/watchers/view.watcher.d.ts +51 -0
- package/dist/watchers/view.watcher.d.ts.map +1 -0
- package/dist/watchers/view.watcher.js +219 -0
- package/dist/watchers/view.watcher.js.map +1 -0
- package/package.json +86 -0
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var GateWatcher_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.GateWatcher = exports.NESTLENS_GATE_SERVICE = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const collector_service_1 = require("../core/collector.service");
|
|
19
|
+
const nestlens_config_1 = require("../nestlens.config");
|
|
20
|
+
/**
|
|
21
|
+
* Token for injecting authorization/gate service
|
|
22
|
+
*/
|
|
23
|
+
exports.NESTLENS_GATE_SERVICE = Symbol('NESTLENS_GATE_SERVICE');
|
|
24
|
+
/**
|
|
25
|
+
* GateWatcher tracks authorization checks in NestJS applications.
|
|
26
|
+
* Monitors gate/policy evaluations to track what resources users can access,
|
|
27
|
+
* capturing gate name, action, subject, allowed/denied status, and user information.
|
|
28
|
+
*/
|
|
29
|
+
let GateWatcher = GateWatcher_1 = class GateWatcher {
|
|
30
|
+
constructor(collector, nestlensConfig, gateService) {
|
|
31
|
+
this.collector = collector;
|
|
32
|
+
this.nestlensConfig = nestlensConfig;
|
|
33
|
+
this.gateService = gateService;
|
|
34
|
+
this.logger = new common_1.Logger(GateWatcher_1.name);
|
|
35
|
+
const watcherConfig = nestlensConfig.watchers?.gate;
|
|
36
|
+
this.config =
|
|
37
|
+
typeof watcherConfig === 'object'
|
|
38
|
+
? watcherConfig
|
|
39
|
+
: { enabled: watcherConfig !== false };
|
|
40
|
+
}
|
|
41
|
+
onModuleInit() {
|
|
42
|
+
if (!this.config.enabled) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
// Check if gate service was provided
|
|
46
|
+
if (!this.gateService) {
|
|
47
|
+
this.logger.debug('GateWatcher: No gate service found. ' +
|
|
48
|
+
'To enable gate tracking, provide a gate/authorization service.');
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
this.setupInterceptors();
|
|
52
|
+
}
|
|
53
|
+
setupInterceptors() {
|
|
54
|
+
if (!this.gateService)
|
|
55
|
+
return;
|
|
56
|
+
// Try to wrap common authorization methods
|
|
57
|
+
this.wrapMethod('check');
|
|
58
|
+
this.wrapMethod('allows');
|
|
59
|
+
this.wrapMethod('denies');
|
|
60
|
+
this.wrapMethod('authorize');
|
|
61
|
+
this.wrapMethod('can');
|
|
62
|
+
this.logger.log('Gate interceptors installed');
|
|
63
|
+
}
|
|
64
|
+
wrapMethod(methodName) {
|
|
65
|
+
if (!this.gateService || typeof this.gateService[methodName] !== 'function') {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
const originalMethod = this.gateService[methodName].bind(this.gateService);
|
|
69
|
+
this.gateService[methodName] = async (gate, action, subject, user) => {
|
|
70
|
+
const startTime = Date.now();
|
|
71
|
+
try {
|
|
72
|
+
const allowed = await originalMethod(gate, action, subject, user);
|
|
73
|
+
const duration = Date.now() - startTime;
|
|
74
|
+
// Track authorization check
|
|
75
|
+
this.collectEntry(gate, action || 'check', subject, allowed, user, undefined, duration);
|
|
76
|
+
return allowed;
|
|
77
|
+
}
|
|
78
|
+
catch (error) {
|
|
79
|
+
const duration = Date.now() - startTime;
|
|
80
|
+
// Track failed authorization check
|
|
81
|
+
this.collectEntry(gate, action || 'check', subject, false, user, error instanceof Error ? error.message : String(error), duration);
|
|
82
|
+
throw error; // Re-throw to maintain original behavior
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Manual tracking method for authorization checks.
|
|
88
|
+
* Call this manually from your authorization logic if auto-wrapping doesn't work.
|
|
89
|
+
*/
|
|
90
|
+
trackCheck(gate, action, subject, allowed, user, reason) {
|
|
91
|
+
this.collectEntry(gate, action, subject, allowed, user, reason, 0);
|
|
92
|
+
}
|
|
93
|
+
collectEntry(gate, action, subject, allowed, user, reason, duration = 0) {
|
|
94
|
+
// Check if this gate/ability should be ignored
|
|
95
|
+
if (this.shouldIgnore(gate, action)) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
const userId = this.extractUserId(user);
|
|
99
|
+
const subjectName = this.extractSubjectName(subject);
|
|
100
|
+
const payload = {
|
|
101
|
+
gate,
|
|
102
|
+
action,
|
|
103
|
+
subject: subjectName,
|
|
104
|
+
allowed,
|
|
105
|
+
userId,
|
|
106
|
+
reason,
|
|
107
|
+
duration,
|
|
108
|
+
context: this.config.captureContext !== false
|
|
109
|
+
? this.captureContext(subject, user)
|
|
110
|
+
: undefined,
|
|
111
|
+
};
|
|
112
|
+
this.collector.collect('gate', payload);
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Check if a gate/ability should be ignored based on configuration
|
|
116
|
+
*/
|
|
117
|
+
shouldIgnore(gate, action) {
|
|
118
|
+
const ignoreList = this.config.ignoreAbilities;
|
|
119
|
+
if (!ignoreList || ignoreList.length === 0) {
|
|
120
|
+
return false;
|
|
121
|
+
}
|
|
122
|
+
// Check both gate name and action against ignore list
|
|
123
|
+
return ignoreList.some((ignored) => ignored === gate ||
|
|
124
|
+
ignored === action ||
|
|
125
|
+
ignored === `${gate}:${action}`);
|
|
126
|
+
}
|
|
127
|
+
extractUserId(user) {
|
|
128
|
+
if (!user)
|
|
129
|
+
return undefined;
|
|
130
|
+
try {
|
|
131
|
+
if (typeof user === 'object' && user !== null) {
|
|
132
|
+
const u = user;
|
|
133
|
+
// Try common user ID fields
|
|
134
|
+
return (u.id || u.userId || u.sub || u._id);
|
|
135
|
+
}
|
|
136
|
+
if (typeof user === 'string' || typeof user === 'number') {
|
|
137
|
+
return user;
|
|
138
|
+
}
|
|
139
|
+
return undefined;
|
|
140
|
+
}
|
|
141
|
+
catch {
|
|
142
|
+
return undefined;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
extractSubjectName(subject) {
|
|
146
|
+
if (!subject)
|
|
147
|
+
return undefined;
|
|
148
|
+
try {
|
|
149
|
+
// If subject is a string, use it directly
|
|
150
|
+
if (typeof subject === 'string') {
|
|
151
|
+
return subject;
|
|
152
|
+
}
|
|
153
|
+
// If subject is an object with a name or type field
|
|
154
|
+
if (typeof subject === 'object' && subject !== null) {
|
|
155
|
+
const s = subject;
|
|
156
|
+
return (s.name || s.type || s.constructor?.name);
|
|
157
|
+
}
|
|
158
|
+
return undefined;
|
|
159
|
+
}
|
|
160
|
+
catch {
|
|
161
|
+
return undefined;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
captureContext(subject, user) {
|
|
165
|
+
try {
|
|
166
|
+
const context = {};
|
|
167
|
+
// Capture subject details
|
|
168
|
+
if (typeof subject === 'object' && subject !== null) {
|
|
169
|
+
const s = subject;
|
|
170
|
+
if (s.id)
|
|
171
|
+
context.subjectId = s.id;
|
|
172
|
+
if (s.type)
|
|
173
|
+
context.subjectType = s.type;
|
|
174
|
+
}
|
|
175
|
+
// Capture user details
|
|
176
|
+
if (typeof user === 'object' && user !== null) {
|
|
177
|
+
const u = user;
|
|
178
|
+
if (u.email)
|
|
179
|
+
context.userEmail = u.email;
|
|
180
|
+
if (u.name)
|
|
181
|
+
context.userName = u.name;
|
|
182
|
+
if (u.roles)
|
|
183
|
+
context.userRoles = u.roles;
|
|
184
|
+
}
|
|
185
|
+
return Object.keys(context).length > 0 ? context : undefined;
|
|
186
|
+
}
|
|
187
|
+
catch {
|
|
188
|
+
return undefined;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
exports.GateWatcher = GateWatcher;
|
|
193
|
+
exports.GateWatcher = GateWatcher = GateWatcher_1 = __decorate([
|
|
194
|
+
(0, common_1.Injectable)(),
|
|
195
|
+
__param(1, (0, common_1.Inject)(nestlens_config_1.NESTLENS_CONFIG)),
|
|
196
|
+
__param(2, (0, common_1.Optional)()),
|
|
197
|
+
__param(2, (0, common_1.Inject)(exports.NESTLENS_GATE_SERVICE)),
|
|
198
|
+
__metadata("design:paramtypes", [collector_service_1.CollectorService, Object, Object])
|
|
199
|
+
], GateWatcher);
|
|
200
|
+
//# sourceMappingURL=gate.watcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gate.watcher.js","sourceRoot":"","sources":["../../src/watchers/gate.watcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { CollectorService } from '../core/collector.service';
|
|
3
|
+
import { NestLensConfig } from '../nestlens.config';
|
|
4
|
+
type AxiosInstance = any;
|
|
5
|
+
export declare const NESTLENS_HTTP_CLIENT: unique symbol;
|
|
6
|
+
export declare class HttpClientWatcher implements OnModuleInit {
|
|
7
|
+
private readonly collector;
|
|
8
|
+
private readonly nestlensConfig;
|
|
9
|
+
private readonly axiosInstance?;
|
|
10
|
+
private readonly logger;
|
|
11
|
+
private readonly config;
|
|
12
|
+
private readonly maxBodySize;
|
|
13
|
+
constructor(collector: CollectorService, nestlensConfig: NestLensConfig, axiosInstance?: AxiosInstance | undefined);
|
|
14
|
+
onModuleInit(): void;
|
|
15
|
+
/**
|
|
16
|
+
* Setup interceptors on an axios instance.
|
|
17
|
+
* Can be called manually if you want to track a specific axios instance.
|
|
18
|
+
*/
|
|
19
|
+
setupInterceptors(axiosInstance: AxiosInstance): void;
|
|
20
|
+
private collectEntry;
|
|
21
|
+
private static readonly DEFAULT_SENSITIVE_HEADERS;
|
|
22
|
+
private static readonly DEFAULT_SENSITIVE_REQUEST_PARAMS;
|
|
23
|
+
private static readonly DEFAULT_SENSITIVE_RESPONSE_PARAMS;
|
|
24
|
+
private captureHeaders;
|
|
25
|
+
private static readonly MAX_MASK_DEPTH;
|
|
26
|
+
/**
|
|
27
|
+
* Recursively mask sensitive data in objects
|
|
28
|
+
* Includes depth limiting to prevent stack overflow on deeply nested objects
|
|
29
|
+
*/
|
|
30
|
+
private maskSensitiveData;
|
|
31
|
+
private captureBody;
|
|
32
|
+
}
|
|
33
|
+
export {};
|
|
34
|
+
//# sourceMappingURL=http-client.watcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-client.watcher.d.ts","sourceRoot":"","sources":["../../src/watchers/http-client.watcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,YAAY,EAAoB,MAAM,gBAAgB,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAEL,cAAc,EAEf,MAAM,oBAAoB,CAAC;AAI5B,KAAK,aAAa,GAAG,GAAG,CAAC;AAGzB,eAAO,MAAM,oBAAoB,eAAiC,CAAC;AAEnE,qBACa,iBAAkB,YAAW,YAAY;IAMlD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAE1B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAG/B,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC;IAVjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsC;IAC7D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA0B;IACjD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;gBAGlB,SAAS,EAAE,gBAAgB,EAE3B,cAAc,EAAE,cAAc,EAG9B,aAAa,CAAC,EAAE,aAAa,YAAA;IAUhD,YAAY;IAiBZ;;;OAGG;IACH,iBAAiB,CAAC,aAAa,EAAE,aAAa,GAAG,IAAI;IAqDrD,OAAO,CAAC,YAAY;IAuEpB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,yBAAyB,CAM/C;IAGF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gCAAgC,CAatD;IAGF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iCAAiC,CAQvD;IAEF,OAAO,CAAC,cAAc;IA6BtB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAM;IAE5C;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAwCzB,OAAO,CAAC,WAAW;CAoBpB"}
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var HttpClientWatcher_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.HttpClientWatcher = exports.NESTLENS_HTTP_CLIENT = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const collector_service_1 = require("../core/collector.service");
|
|
19
|
+
const nestlens_config_1 = require("../nestlens.config");
|
|
20
|
+
// Token for injecting custom axios instance
|
|
21
|
+
exports.NESTLENS_HTTP_CLIENT = Symbol('NESTLENS_HTTP_CLIENT');
|
|
22
|
+
let HttpClientWatcher = HttpClientWatcher_1 = class HttpClientWatcher {
|
|
23
|
+
constructor(collector, nestlensConfig, axiosInstance) {
|
|
24
|
+
this.collector = collector;
|
|
25
|
+
this.nestlensConfig = nestlensConfig;
|
|
26
|
+
this.axiosInstance = axiosInstance;
|
|
27
|
+
this.logger = new common_1.Logger(HttpClientWatcher_1.name);
|
|
28
|
+
const watcherConfig = nestlensConfig.watchers?.httpClient;
|
|
29
|
+
this.config =
|
|
30
|
+
typeof watcherConfig === 'object'
|
|
31
|
+
? watcherConfig
|
|
32
|
+
: { enabled: watcherConfig !== false };
|
|
33
|
+
this.maxBodySize = this.config.maxBodySize || 64 * 1024; // 64KB default
|
|
34
|
+
}
|
|
35
|
+
onModuleInit() {
|
|
36
|
+
if (!this.config.enabled) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
// Check if axios instance was provided
|
|
40
|
+
if (!this.axiosInstance) {
|
|
41
|
+
this.logger.debug('HttpClientWatcher: No axios instance provided. ' +
|
|
42
|
+
'To enable HTTP client tracking, provide your axios/HttpService instance with NESTLENS_HTTP_CLIENT token.');
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this.setupInterceptors(this.axiosInstance);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Setup interceptors on an axios instance.
|
|
49
|
+
* Can be called manually if you want to track a specific axios instance.
|
|
50
|
+
*/
|
|
51
|
+
setupInterceptors(axiosInstance) {
|
|
52
|
+
if (!axiosInstance || typeof axiosInstance.interceptors !== 'object') {
|
|
53
|
+
this.logger.warn('Invalid axios instance provided');
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
const axios = axiosInstance.axiosRef || axiosInstance;
|
|
57
|
+
// Request interceptor - capture start time
|
|
58
|
+
axios.interceptors.request.use(
|
|
59
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
60
|
+
(config) => {
|
|
61
|
+
config.metadata = {
|
|
62
|
+
...config.metadata,
|
|
63
|
+
nestlensStartTime: Date.now(),
|
|
64
|
+
};
|
|
65
|
+
return config;
|
|
66
|
+
},
|
|
67
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
68
|
+
(error) => {
|
|
69
|
+
return Promise.reject(error);
|
|
70
|
+
});
|
|
71
|
+
// Response interceptor - capture response and log
|
|
72
|
+
axios.interceptors.response.use(
|
|
73
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
74
|
+
(response) => {
|
|
75
|
+
this.collectEntry(response.config, response.status, response.headers, response.data);
|
|
76
|
+
return response;
|
|
77
|
+
},
|
|
78
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
79
|
+
(error) => {
|
|
80
|
+
const config = error.config;
|
|
81
|
+
const status = error.response?.status;
|
|
82
|
+
const headers = error.response?.headers;
|
|
83
|
+
const data = error.response?.data;
|
|
84
|
+
this.collectEntry(config, status, headers, data, error.message);
|
|
85
|
+
return Promise.reject(error);
|
|
86
|
+
});
|
|
87
|
+
this.logger.log('HTTP Client interceptors installed');
|
|
88
|
+
}
|
|
89
|
+
collectEntry(config, statusCode, responseHeaders, responseData, errorMessage) {
|
|
90
|
+
if (!config)
|
|
91
|
+
return;
|
|
92
|
+
const startTime = config.metadata?.nestlensStartTime || Date.now();
|
|
93
|
+
const duration = Date.now() - startTime;
|
|
94
|
+
// Parse URL
|
|
95
|
+
let hostname;
|
|
96
|
+
let path;
|
|
97
|
+
const fullUrl = config.url || '';
|
|
98
|
+
try {
|
|
99
|
+
const url = new URL(fullUrl);
|
|
100
|
+
hostname = url.hostname;
|
|
101
|
+
path = url.pathname + url.search;
|
|
102
|
+
}
|
|
103
|
+
catch {
|
|
104
|
+
// Relative URL or invalid
|
|
105
|
+
path = fullUrl;
|
|
106
|
+
}
|
|
107
|
+
// Check if host should be ignored
|
|
108
|
+
if (hostname && this.config.ignoreHosts?.some((h) => hostname?.includes(h))) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
// Merge default and custom sensitive params
|
|
112
|
+
const sensitiveRequestParams = [
|
|
113
|
+
...HttpClientWatcher_1.DEFAULT_SENSITIVE_REQUEST_PARAMS,
|
|
114
|
+
...(this.config.sensitiveRequestParams || []),
|
|
115
|
+
];
|
|
116
|
+
const sensitiveResponseParams = [
|
|
117
|
+
...HttpClientWatcher_1.DEFAULT_SENSITIVE_RESPONSE_PARAMS,
|
|
118
|
+
...(this.config.sensitiveResponseParams || []),
|
|
119
|
+
];
|
|
120
|
+
const payload = {
|
|
121
|
+
method: (config.method || 'GET').toUpperCase(),
|
|
122
|
+
url: fullUrl,
|
|
123
|
+
hostname,
|
|
124
|
+
path,
|
|
125
|
+
requestHeaders: this.captureHeaders(config.headers),
|
|
126
|
+
requestBody: this.config.captureRequestBody !== false
|
|
127
|
+
? this.captureBody(config.data, sensitiveRequestParams)
|
|
128
|
+
: undefined,
|
|
129
|
+
statusCode,
|
|
130
|
+
responseHeaders: this.captureHeaders(responseHeaders),
|
|
131
|
+
responseBody: this.config.captureResponseBody !== false
|
|
132
|
+
? this.captureBody(responseData, sensitiveResponseParams)
|
|
133
|
+
: undefined,
|
|
134
|
+
duration,
|
|
135
|
+
error: errorMessage,
|
|
136
|
+
};
|
|
137
|
+
this.collector.collect('http-client', payload);
|
|
138
|
+
}
|
|
139
|
+
captureHeaders(headers) {
|
|
140
|
+
if (!headers)
|
|
141
|
+
return undefined;
|
|
142
|
+
const sensitiveHeaders = [
|
|
143
|
+
...HttpClientWatcher_1.DEFAULT_SENSITIVE_HEADERS,
|
|
144
|
+
...(this.config.sensitiveHeaders || []),
|
|
145
|
+
].map((h) => h.toLowerCase());
|
|
146
|
+
const result = {};
|
|
147
|
+
for (const [key, value] of Object.entries(headers)) {
|
|
148
|
+
const lowerKey = key.toLowerCase();
|
|
149
|
+
if (sensitiveHeaders.includes(lowerKey)) {
|
|
150
|
+
result[key] = '********';
|
|
151
|
+
}
|
|
152
|
+
else if (typeof value === 'string') {
|
|
153
|
+
result[key] = value;
|
|
154
|
+
}
|
|
155
|
+
else if (typeof value === 'number' || typeof value === 'boolean') {
|
|
156
|
+
result[key] = String(value);
|
|
157
|
+
}
|
|
158
|
+
else if (Array.isArray(value)) {
|
|
159
|
+
result[key] = value.join(', ');
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
return Object.keys(result).length > 0 ? result : undefined;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Recursively mask sensitive data in objects
|
|
166
|
+
* Includes depth limiting to prevent stack overflow on deeply nested objects
|
|
167
|
+
*/
|
|
168
|
+
maskSensitiveData(data, sensitiveKeys, replacement = '********', depth = 0) {
|
|
169
|
+
if (data === null || data === undefined)
|
|
170
|
+
return data;
|
|
171
|
+
if (typeof data !== 'object')
|
|
172
|
+
return data;
|
|
173
|
+
// Prevent stack overflow on deeply nested objects
|
|
174
|
+
if (depth >= HttpClientWatcher_1.MAX_MASK_DEPTH) {
|
|
175
|
+
return { _truncated: true, _reason: 'max_depth_exceeded' };
|
|
176
|
+
}
|
|
177
|
+
if (Array.isArray(data)) {
|
|
178
|
+
return data.map((item) => this.maskSensitiveData(item, sensitiveKeys, replacement, depth + 1));
|
|
179
|
+
}
|
|
180
|
+
const masked = {};
|
|
181
|
+
const lowerSensitiveKeys = sensitiveKeys.map((k) => k.toLowerCase());
|
|
182
|
+
for (const [key, value] of Object.entries(data)) {
|
|
183
|
+
const lowerKey = key.toLowerCase();
|
|
184
|
+
// Check if key contains any sensitive pattern
|
|
185
|
+
const isSensitive = lowerSensitiveKeys.some((s) => lowerKey.includes(s));
|
|
186
|
+
if (isSensitive) {
|
|
187
|
+
masked[key] = replacement;
|
|
188
|
+
}
|
|
189
|
+
else if (typeof value === 'object' && value !== null) {
|
|
190
|
+
masked[key] = this.maskSensitiveData(value, sensitiveKeys, replacement, depth + 1);
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
masked[key] = value;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
return masked;
|
|
197
|
+
}
|
|
198
|
+
captureBody(body, sensitiveParams) {
|
|
199
|
+
if (body === undefined || body === null)
|
|
200
|
+
return undefined;
|
|
201
|
+
try {
|
|
202
|
+
// First mask sensitive data
|
|
203
|
+
const maskedBody = this.maskSensitiveData(body, sensitiveParams);
|
|
204
|
+
// Then check size
|
|
205
|
+
const json = JSON.stringify(maskedBody);
|
|
206
|
+
if (json.length > this.maxBodySize) {
|
|
207
|
+
return { _truncated: true, _size: json.length };
|
|
208
|
+
}
|
|
209
|
+
return maskedBody;
|
|
210
|
+
}
|
|
211
|
+
catch {
|
|
212
|
+
return { _error: 'Unable to serialize body' };
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
};
|
|
216
|
+
exports.HttpClientWatcher = HttpClientWatcher;
|
|
217
|
+
// Default sensitive headers to mask
|
|
218
|
+
HttpClientWatcher.DEFAULT_SENSITIVE_HEADERS = [
|
|
219
|
+
'authorization',
|
|
220
|
+
'cookie',
|
|
221
|
+
'set-cookie',
|
|
222
|
+
'x-api-key',
|
|
223
|
+
'x-auth-token',
|
|
224
|
+
];
|
|
225
|
+
// Default sensitive request params to mask
|
|
226
|
+
HttpClientWatcher.DEFAULT_SENSITIVE_REQUEST_PARAMS = [
|
|
227
|
+
'password',
|
|
228
|
+
'password_confirmation',
|
|
229
|
+
'current_password',
|
|
230
|
+
'new_password',
|
|
231
|
+
'credit_card',
|
|
232
|
+
'card_number',
|
|
233
|
+
'cvv',
|
|
234
|
+
'cvc',
|
|
235
|
+
'pin',
|
|
236
|
+
'ssn',
|
|
237
|
+
'social_security',
|
|
238
|
+
'secret',
|
|
239
|
+
];
|
|
240
|
+
// Default sensitive response params to mask
|
|
241
|
+
HttpClientWatcher.DEFAULT_SENSITIVE_RESPONSE_PARAMS = [
|
|
242
|
+
'access_token',
|
|
243
|
+
'refresh_token',
|
|
244
|
+
'api_key',
|
|
245
|
+
'api_secret',
|
|
246
|
+
'private_key',
|
|
247
|
+
'secret',
|
|
248
|
+
'token',
|
|
249
|
+
];
|
|
250
|
+
// Maximum recursion depth for masking to prevent stack overflow
|
|
251
|
+
HttpClientWatcher.MAX_MASK_DEPTH = 10;
|
|
252
|
+
exports.HttpClientWatcher = HttpClientWatcher = HttpClientWatcher_1 = __decorate([
|
|
253
|
+
(0, common_1.Injectable)(),
|
|
254
|
+
__param(1, (0, common_1.Inject)(nestlens_config_1.NESTLENS_CONFIG)),
|
|
255
|
+
__param(2, (0, common_1.Optional)()),
|
|
256
|
+
__param(2, (0, common_1.Inject)(exports.NESTLENS_HTTP_CLIENT)),
|
|
257
|
+
__metadata("design:paramtypes", [collector_service_1.CollectorService, Object, Object])
|
|
258
|
+
], HttpClientWatcher);
|
|
259
|
+
//# sourceMappingURL=http-client.watcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-client.watcher.js","sourceRoot":"","sources":["../../src/watchers/http-client.watcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export * from './request.watcher';
|
|
2
|
+
export * from './query';
|
|
3
|
+
export * from './exception.watcher';
|
|
4
|
+
export * from './log.watcher';
|
|
5
|
+
export * from './http-client.watcher';
|
|
6
|
+
export * from './cache.watcher';
|
|
7
|
+
export * from './event.watcher';
|
|
8
|
+
export * from './job.watcher';
|
|
9
|
+
export * from './schedule.watcher';
|
|
10
|
+
export * from './mail.watcher';
|
|
11
|
+
export * from './redis.watcher';
|
|
12
|
+
export * from './model.watcher';
|
|
13
|
+
export * from './notification.watcher';
|
|
14
|
+
export * from './view.watcher';
|
|
15
|
+
export * from './command.watcher';
|
|
16
|
+
export * from './gate.watcher';
|
|
17
|
+
export * from './batch.watcher';
|
|
18
|
+
export * from './dump.watcher';
|
|
19
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/watchers/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,SAAS,CAAC;AACxB,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./request.watcher"), exports);
|
|
18
|
+
__exportStar(require("./query"), exports);
|
|
19
|
+
__exportStar(require("./exception.watcher"), exports);
|
|
20
|
+
__exportStar(require("./log.watcher"), exports);
|
|
21
|
+
__exportStar(require("./http-client.watcher"), exports);
|
|
22
|
+
__exportStar(require("./cache.watcher"), exports);
|
|
23
|
+
__exportStar(require("./event.watcher"), exports);
|
|
24
|
+
__exportStar(require("./job.watcher"), exports);
|
|
25
|
+
__exportStar(require("./schedule.watcher"), exports);
|
|
26
|
+
__exportStar(require("./mail.watcher"), exports);
|
|
27
|
+
__exportStar(require("./redis.watcher"), exports);
|
|
28
|
+
__exportStar(require("./model.watcher"), exports);
|
|
29
|
+
__exportStar(require("./notification.watcher"), exports);
|
|
30
|
+
__exportStar(require("./view.watcher"), exports);
|
|
31
|
+
__exportStar(require("./command.watcher"), exports);
|
|
32
|
+
__exportStar(require("./gate.watcher"), exports);
|
|
33
|
+
__exportStar(require("./batch.watcher"), exports);
|
|
34
|
+
__exportStar(require("./dump.watcher"), exports);
|
|
35
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/watchers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,0CAAwB;AACxB,sDAAoC;AACpC,gDAA8B;AAC9B,wDAAsC;AACtC,kDAAgC;AAChC,kDAAgC;AAChC,gDAA8B;AAC9B,qDAAmC;AACnC,iDAA+B;AAC/B,kDAAgC;AAChC,kDAAgC;AAChC,yDAAuC;AACvC,iDAA+B;AAC/B,oDAAkC;AAClC,iDAA+B;AAC/B,kDAAgC;AAChC,iDAA+B"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { CollectorService } from '../core/collector.service';
|
|
3
|
+
import { NestLensConfig } from '../nestlens.config';
|
|
4
|
+
type BullQueue = any;
|
|
5
|
+
export declare const NESTLENS_BULL_QUEUES: unique symbol;
|
|
6
|
+
export declare class JobWatcher implements OnModuleInit {
|
|
7
|
+
private readonly collector;
|
|
8
|
+
private readonly nestlensConfig;
|
|
9
|
+
private readonly logger;
|
|
10
|
+
private readonly config;
|
|
11
|
+
private readonly jobTracking;
|
|
12
|
+
constructor(collector: CollectorService, nestlensConfig: NestLensConfig);
|
|
13
|
+
onModuleInit(): void;
|
|
14
|
+
/**
|
|
15
|
+
* Setup interceptors on a Bull/BullMQ queue.
|
|
16
|
+
* Call this manually for each queue you want to track.
|
|
17
|
+
*/
|
|
18
|
+
setupQueue(queue: BullQueue, queueName?: string): void;
|
|
19
|
+
private handleJobWaiting;
|
|
20
|
+
private handleJobActive;
|
|
21
|
+
private handleJobCompleted;
|
|
22
|
+
private handleJobFailed;
|
|
23
|
+
private handleJobDelayed;
|
|
24
|
+
private captureData;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=job.watcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"job.watcher.d.ts","sourceRoot":"","sources":["../../src/watchers/job.watcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8B,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAEL,cAAc,EAEf,MAAM,oBAAoB,CAAC;AAI5B,KAAK,SAAS,GAAG,GAAG,CAAC;AAGrB,eAAO,MAAM,oBAAoB,eAAiC,CAAC;AAEnE,qBACa,UAAW,YAAW,YAAY;IAM3C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAE1B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAPjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+B;IACtD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmB;IAC1C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAA6B;gBAGtC,SAAS,EAAE,gBAAgB,EAE3B,cAAc,EAAE,cAAc;IASjD,YAAY;IAUZ;;;OAGG;IACH,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI;YAoCxC,gBAAgB;IAuB9B,OAAO,CAAC,eAAe;IAmBvB,OAAO,CAAC,kBAAkB;IA2B1B,OAAO,CAAC,eAAe;YA2BT,gBAAgB;IAuB9B,OAAO,CAAC,WAAW;CAepB"}
|