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,294 @@
|
|
|
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 NestLensGuard_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.NestLensGuard = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const nestlens_config_1 = require("../nestlens.config");
|
|
19
|
+
/**
|
|
20
|
+
* Default rate limit configuration
|
|
21
|
+
*/
|
|
22
|
+
const DEFAULT_RATE_LIMIT = {
|
|
23
|
+
windowMs: 60 * 1000, // 1 minute
|
|
24
|
+
maxRequests: 100, // 100 requests per minute per IP
|
|
25
|
+
};
|
|
26
|
+
let NestLensGuard = NestLensGuard_1 = class NestLensGuard {
|
|
27
|
+
constructor(config) {
|
|
28
|
+
this.config = config;
|
|
29
|
+
this.logger = new common_1.Logger(NestLensGuard_1.name);
|
|
30
|
+
/**
|
|
31
|
+
* In-memory rate limit store
|
|
32
|
+
* Key: IP address, Value: request count and reset time
|
|
33
|
+
*/
|
|
34
|
+
this.rateLimitStore = new Map();
|
|
35
|
+
// Periodic cleanup of expired rate limit entries
|
|
36
|
+
this.cleanupInterval = setInterval(() => {
|
|
37
|
+
this.cleanupExpiredEntries();
|
|
38
|
+
}, 5 * 60 * 1000);
|
|
39
|
+
// Prevent interval from keeping the process alive
|
|
40
|
+
if (this.cleanupInterval.unref) {
|
|
41
|
+
this.cleanupInterval.unref();
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
async canActivate(context) {
|
|
45
|
+
const request = context.switchToHttp().getRequest();
|
|
46
|
+
// Check if NestLens is enabled
|
|
47
|
+
if (this.config.enabled === false) {
|
|
48
|
+
return false;
|
|
49
|
+
}
|
|
50
|
+
// Check rate limit first (before any other checks)
|
|
51
|
+
const clientIp = this.getClientIp(request);
|
|
52
|
+
if (!this.checkRateLimit(clientIp)) {
|
|
53
|
+
throw new common_1.HttpException({
|
|
54
|
+
statusCode: common_1.HttpStatus.TOO_MANY_REQUESTS,
|
|
55
|
+
message: 'Too many requests. Please try again later.',
|
|
56
|
+
retryAfter: Math.ceil(this.getRateLimitResetTime(clientIp) / 1000),
|
|
57
|
+
}, common_1.HttpStatus.TOO_MANY_REQUESTS);
|
|
58
|
+
}
|
|
59
|
+
// Get merged authorization config (new config takes precedence over legacy)
|
|
60
|
+
const authConfig = this.getMergedAuthConfig();
|
|
61
|
+
// 1. Check environment
|
|
62
|
+
if (!this.isEnvironmentAllowed(authConfig)) {
|
|
63
|
+
this.logger.warn(`Access denied: Environment '${this.getCurrentEnvironment(authConfig)}' not in allowed list`);
|
|
64
|
+
throw new common_1.ForbiddenException('NestLens is not available in this environment');
|
|
65
|
+
}
|
|
66
|
+
// 2. Check IP whitelist
|
|
67
|
+
const allowedIps = authConfig.allowedIps;
|
|
68
|
+
if (allowedIps && allowedIps.length > 0) {
|
|
69
|
+
const clientIp = this.getClientIp(request);
|
|
70
|
+
if (!this.isIpAllowed(clientIp, allowedIps)) {
|
|
71
|
+
this.logger.warn(`Access denied: IP '${clientIp}' not in allowed list`);
|
|
72
|
+
throw new common_1.ForbiddenException('Access denied from this IP address');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
// 3. Check custom access function
|
|
76
|
+
const canAccess = authConfig.canAccess;
|
|
77
|
+
if (canAccess) {
|
|
78
|
+
const result = await this.evaluateCanAccess(canAccess, request);
|
|
79
|
+
if (result === false) {
|
|
80
|
+
this.logger.warn('Access denied: canAccess function returned false');
|
|
81
|
+
throw new common_1.ForbiddenException('Access denied');
|
|
82
|
+
}
|
|
83
|
+
// If result is an AuthUser object, attach to request and check roles
|
|
84
|
+
if (typeof result === 'object' && result !== null) {
|
|
85
|
+
request.nestlensUser = result;
|
|
86
|
+
// 4. Check required roles
|
|
87
|
+
if (authConfig.requiredRoles && authConfig.requiredRoles.length > 0) {
|
|
88
|
+
if (!this.hasRequiredRoles(request.nestlensUser, authConfig.requiredRoles)) {
|
|
89
|
+
this.logger.warn(`Access denied: User missing required roles. Required: ${authConfig.requiredRoles.join(', ')}`);
|
|
90
|
+
throw new common_1.ForbiddenException('Insufficient permissions');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Merge legacy config options with new authorization config
|
|
99
|
+
*/
|
|
100
|
+
getMergedAuthConfig() {
|
|
101
|
+
const authConfig = this.config.authorization || {};
|
|
102
|
+
return {
|
|
103
|
+
allowedEnvironments: authConfig.allowedEnvironments ?? ['development', 'local', 'test'],
|
|
104
|
+
environmentVariable: authConfig.environmentVariable ?? 'NODE_ENV',
|
|
105
|
+
// Legacy options as fallback
|
|
106
|
+
allowedIps: authConfig.allowedIps ?? this.config.allowedIps,
|
|
107
|
+
canAccess: authConfig.canAccess ?? this.config.canAccess,
|
|
108
|
+
requiredRoles: authConfig.requiredRoles,
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Check if current environment is allowed
|
|
113
|
+
*/
|
|
114
|
+
isEnvironmentAllowed(authConfig) {
|
|
115
|
+
const allowedEnvs = authConfig.allowedEnvironments;
|
|
116
|
+
// null means all environments are allowed
|
|
117
|
+
if (allowedEnvs === null || allowedEnvs === undefined) {
|
|
118
|
+
return true;
|
|
119
|
+
}
|
|
120
|
+
// Empty array means no environment is allowed
|
|
121
|
+
if (allowedEnvs.length === 0) {
|
|
122
|
+
return false;
|
|
123
|
+
}
|
|
124
|
+
const currentEnv = this.getCurrentEnvironment(authConfig);
|
|
125
|
+
return allowedEnvs.includes(currentEnv);
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Get current environment from configured variable
|
|
129
|
+
*/
|
|
130
|
+
getCurrentEnvironment(authConfig) {
|
|
131
|
+
const envVar = authConfig.environmentVariable || 'NODE_ENV';
|
|
132
|
+
return process.env[envVar] || 'development';
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Evaluate canAccess function
|
|
136
|
+
*/
|
|
137
|
+
async evaluateCanAccess(canAccess, request) {
|
|
138
|
+
try {
|
|
139
|
+
const result = canAccess(request);
|
|
140
|
+
return result instanceof Promise ? await result : result;
|
|
141
|
+
}
|
|
142
|
+
catch (error) {
|
|
143
|
+
this.logger.error(`Error in canAccess function: ${error}`);
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Check if user has all required roles
|
|
149
|
+
*/
|
|
150
|
+
hasRequiredRoles(user, requiredRoles) {
|
|
151
|
+
if (!user.roles || user.roles.length === 0) {
|
|
152
|
+
return false;
|
|
153
|
+
}
|
|
154
|
+
return requiredRoles.every((role) => user.roles.includes(role));
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Get client IP from request
|
|
158
|
+
*/
|
|
159
|
+
getClientIp(request) {
|
|
160
|
+
const forwardedFor = request.headers['x-forwarded-for'];
|
|
161
|
+
if (forwardedFor) {
|
|
162
|
+
const ips = Array.isArray(forwardedFor)
|
|
163
|
+
? forwardedFor[0]
|
|
164
|
+
: forwardedFor.split(',')[0];
|
|
165
|
+
return ips.trim();
|
|
166
|
+
}
|
|
167
|
+
return request.ip || request.socket?.remoteAddress || '';
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Check if IP matches allowed patterns
|
|
171
|
+
* Uses safe wildcard matching instead of regex to prevent ReDoS attacks
|
|
172
|
+
*/
|
|
173
|
+
isIpAllowed(clientIp, allowedIps) {
|
|
174
|
+
// Normalize IPv6 localhost
|
|
175
|
+
const normalizedIp = clientIp === '::1' ? '127.0.0.1' : clientIp;
|
|
176
|
+
return allowedIps.some((pattern) => {
|
|
177
|
+
// Support wildcard patterns like '192.168.1.*'
|
|
178
|
+
if (pattern.includes('*')) {
|
|
179
|
+
return (this.matchWildcard(normalizedIp, pattern) ||
|
|
180
|
+
this.matchWildcard(clientIp, pattern));
|
|
181
|
+
}
|
|
182
|
+
// Support localhost variations
|
|
183
|
+
if (pattern === 'localhost' || pattern === '127.0.0.1') {
|
|
184
|
+
return (normalizedIp === '127.0.0.1' ||
|
|
185
|
+
clientIp === '::1' ||
|
|
186
|
+
clientIp === '::ffff:127.0.0.1');
|
|
187
|
+
}
|
|
188
|
+
return normalizedIp === pattern || clientIp === pattern;
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Safe wildcard matching without regex (prevents ReDoS)
|
|
193
|
+
* Supports only '*' as wildcard for IP segments
|
|
194
|
+
* Example: '192.168.1.*' matches '192.168.1.100'
|
|
195
|
+
*/
|
|
196
|
+
matchWildcard(ip, pattern) {
|
|
197
|
+
const ipParts = ip.split('.');
|
|
198
|
+
const patternParts = pattern.split('.');
|
|
199
|
+
// IP addresses should have exactly 4 parts
|
|
200
|
+
if (ipParts.length !== 4 || patternParts.length !== 4) {
|
|
201
|
+
return false;
|
|
202
|
+
}
|
|
203
|
+
for (let i = 0; i < 4; i++) {
|
|
204
|
+
const patternPart = patternParts[i];
|
|
205
|
+
const ipPart = ipParts[i];
|
|
206
|
+
// Wildcard matches any segment
|
|
207
|
+
if (patternPart === '*') {
|
|
208
|
+
continue;
|
|
209
|
+
}
|
|
210
|
+
// Exact match required
|
|
211
|
+
if (patternPart !== ipPart) {
|
|
212
|
+
return false;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return true;
|
|
216
|
+
}
|
|
217
|
+
// ============================================================================
|
|
218
|
+
// Rate Limiting
|
|
219
|
+
// ============================================================================
|
|
220
|
+
/**
|
|
221
|
+
* Get rate limit configuration from config or use defaults
|
|
222
|
+
*/
|
|
223
|
+
getRateLimitConfig() {
|
|
224
|
+
const rateLimit = this.config.rateLimit;
|
|
225
|
+
if (rateLimit === false) {
|
|
226
|
+
// Rate limiting disabled - return very high limits
|
|
227
|
+
return { windowMs: 60000, maxRequests: Number.MAX_SAFE_INTEGER };
|
|
228
|
+
}
|
|
229
|
+
if (typeof rateLimit === 'object') {
|
|
230
|
+
return {
|
|
231
|
+
windowMs: rateLimit.windowMs ?? DEFAULT_RATE_LIMIT.windowMs,
|
|
232
|
+
maxRequests: rateLimit.maxRequests ?? DEFAULT_RATE_LIMIT.maxRequests,
|
|
233
|
+
};
|
|
234
|
+
}
|
|
235
|
+
return DEFAULT_RATE_LIMIT;
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* Check if request is within rate limit
|
|
239
|
+
* Returns true if allowed, false if rate limited
|
|
240
|
+
*/
|
|
241
|
+
checkRateLimit(ip) {
|
|
242
|
+
const config = this.getRateLimitConfig();
|
|
243
|
+
const now = Date.now();
|
|
244
|
+
const entry = this.rateLimitStore.get(ip);
|
|
245
|
+
if (!entry || now >= entry.resetAt) {
|
|
246
|
+
// First request or window expired - create new entry
|
|
247
|
+
this.rateLimitStore.set(ip, {
|
|
248
|
+
count: 1,
|
|
249
|
+
resetAt: now + config.windowMs,
|
|
250
|
+
});
|
|
251
|
+
return true;
|
|
252
|
+
}
|
|
253
|
+
// Increment counter
|
|
254
|
+
entry.count++;
|
|
255
|
+
// Check if over limit
|
|
256
|
+
if (entry.count > config.maxRequests) {
|
|
257
|
+
return false;
|
|
258
|
+
}
|
|
259
|
+
return true;
|
|
260
|
+
}
|
|
261
|
+
/**
|
|
262
|
+
* Get time until rate limit resets (in ms)
|
|
263
|
+
*/
|
|
264
|
+
getRateLimitResetTime(ip) {
|
|
265
|
+
const entry = this.rateLimitStore.get(ip);
|
|
266
|
+
if (!entry)
|
|
267
|
+
return 0;
|
|
268
|
+
const remaining = entry.resetAt - Date.now();
|
|
269
|
+
return Math.max(0, remaining);
|
|
270
|
+
}
|
|
271
|
+
/**
|
|
272
|
+
* Cleanup expired rate limit entries to prevent memory leaks
|
|
273
|
+
*/
|
|
274
|
+
cleanupExpiredEntries() {
|
|
275
|
+
const now = Date.now();
|
|
276
|
+
let cleaned = 0;
|
|
277
|
+
for (const [ip, entry] of this.rateLimitStore.entries()) {
|
|
278
|
+
if (now >= entry.resetAt) {
|
|
279
|
+
this.rateLimitStore.delete(ip);
|
|
280
|
+
cleaned++;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
if (cleaned > 0) {
|
|
284
|
+
this.logger.debug(`Cleaned up ${cleaned} expired rate limit entries`);
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
};
|
|
288
|
+
exports.NestLensGuard = NestLensGuard;
|
|
289
|
+
exports.NestLensGuard = NestLensGuard = NestLensGuard_1 = __decorate([
|
|
290
|
+
(0, common_1.Injectable)(),
|
|
291
|
+
__param(0, (0, common_1.Inject)(nestlens_config_1.NESTLENS_CONFIG)),
|
|
292
|
+
__metadata("design:paramtypes", [Object])
|
|
293
|
+
], NestLensGuard);
|
|
294
|
+
//# sourceMappingURL=api.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.guard.js","sourceRoot":"","sources":["../../src/api/api.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CASwB;AAExB,wDAK4B;AAiB5B;;GAEG;AACH,MAAM,kBAAkB,GAAG;IACzB,QAAQ,EAAE,EAAE,GAAG,IAAI,EAAE,WAAW;IAChC,WAAW,EAAE,GAAG,EAAE,iCAAiC;CACpD,CAAC;AAGK,IAAM,aAAa,qBAAnB,MAAM,aAAa;IAcxB,YAEE,MAAuC;QAAtB,WAAM,GAAN,MAAM,CAAgB;QAfxB,WAAM,GAAG,IAAI,eAAM,CAAC,eAAa,CAAC,IAAI,CAAC,CAAC;QAEzD;;;WAGG;QACc,mBAAc,GAAG,IAAI,GAAG,EAA0B,CAAC;QAWlE,iDAAiD;QACjD,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC,GAAG,EAAE;YACtC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QAElB,kDAAkD;QAClD,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;YAC/B,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAyB;QACzC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAmB,CAAC;QAErE,+BAA+B;QAC/B,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE,CAAC;YAClC,OAAO,KAAK,CAAC;QACf,CAAC;QAED,mDAAmD;QACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,sBAAa,CACrB;gBACE,UAAU,EAAE,mBAAU,CAAC,iBAAiB;gBACxC,OAAO,EAAE,4CAA4C;gBACrD,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC;aACnE,EACD,mBAAU,CAAC,iBAAiB,CAC7B,CAAC;QACJ,CAAC;QAED,4EAA4E;QAC5E,MAAM,UAAU,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE9C,uBAAuB;QACvB,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3C,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,+BAA+B,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,uBAAuB,CAC7F,CAAC;YACF,MAAM,IAAI,2BAAkB,CAAC,+CAA+C,CAAC,CAAC;QAChF,CAAC;QAED,wBAAwB;QACxB,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC;QACzC,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC3C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,UAAU,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,QAAQ,uBAAuB,CAAC,CAAC;gBACxE,MAAM,IAAI,2BAAkB,CAAC,oCAAoC,CAAC,CAAC;YACrE,CAAC;QACH,CAAC;QAED,kCAAkC;QAClC,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC;QACvC,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;YAEhE,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;gBACrB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;gBACrE,MAAM,IAAI,2BAAkB,CAAC,eAAe,CAAC,CAAC;YAChD,CAAC;YAED,qEAAqE;YACrE,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;gBAClD,OAAO,CAAC,YAAY,GAAG,MAAkB,CAAC;gBAE1C,0BAA0B;gBAC1B,IAAI,UAAU,CAAC,aAAa,IAAI,UAAU,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpE,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,aAAa,CAAC,EAAE,CAAC;wBAC3E,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,yDAAyD,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC/F,CAAC;wBACF,MAAM,IAAI,2BAAkB,CAAC,0BAA0B,CAAC,CAAC;oBAC3D,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,mBAAmB;QACzB,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,IAAI,EAAE,CAAC;QAEnD,OAAO;YACL,mBAAmB,EAAE,UAAU,CAAC,mBAAmB,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,MAAM,CAAC;YACvF,mBAAmB,EAAE,UAAU,CAAC,mBAAmB,IAAI,UAAU;YACjE,6BAA6B;YAC7B,UAAU,EAAE,UAAU,CAAC,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU;YAC3D,SAAS,EAAE,UAAU,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS;YACxD,aAAa,EAAE,UAAU,CAAC,aAAa;SACxC,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,oBAAoB,CAAC,UAA+B;QAC1D,MAAM,WAAW,GAAG,UAAU,CAAC,mBAAmB,CAAC;QAEnD,0CAA0C;QAC1C,IAAI,WAAW,KAAK,IAAI,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;YACtD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,8CAA8C;QAC9C,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAC1D,OAAO,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED;;OAEG;IACK,qBAAqB,CAAC,UAA+B;QAC3D,MAAM,MAAM,GAAG,UAAU,CAAC,mBAAmB,IAAI,UAAU,CAAC;QAC5D,OAAO,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,aAAa,CAAC;IAC9C,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,iBAAiB,CAC7B,SAAwD,EACxD,OAAgB;QAEhB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC;YAClC,OAAO,MAAM,YAAY,OAAO,CAAC,CAAC,CAAC,MAAM,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;QAC3D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,KAAK,EAAE,CAAC,CAAC;YAC3D,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,IAAc,EAAE,aAAuB;QAC9D,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3C,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,OAAgB;QAClC,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACxD,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC;gBACrC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;gBACjB,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/B,OAAO,GAAG,CAAC,IAAI,EAAE,CAAC;QACpB,CAAC;QACD,OAAO,OAAO,CAAC,EAAE,IAAI,OAAO,CAAC,MAAM,EAAE,aAAa,IAAI,EAAE,CAAC;IAC3D,CAAC;IAED;;;OAGG;IACK,WAAW,CAAC,QAAgB,EAAE,UAAoB;QACxD,2BAA2B;QAC3B,MAAM,YAAY,GAAG,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;QAEjE,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;YACjC,+CAA+C;YAC/C,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC1B,OAAO,CACL,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,OAAO,CAAC;oBACzC,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,CACtC,CAAC;YACJ,CAAC;YACD,+BAA+B;YAC/B,IAAI,OAAO,KAAK,WAAW,IAAI,OAAO,KAAK,WAAW,EAAE,CAAC;gBACvD,OAAO,CACL,YAAY,KAAK,WAAW;oBAC5B,QAAQ,KAAK,KAAK;oBAClB,QAAQ,KAAK,kBAAkB,CAChC,CAAC;YACJ,CAAC;YACD,OAAO,YAAY,KAAK,OAAO,IAAI,QAAQ,KAAK,OAAO,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACK,aAAa,CAAC,EAAU,EAAE,OAAe;QAC/C,MAAM,OAAO,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAExC,2CAA2C;QAC3C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtD,OAAO,KAAK,CAAC;QACf,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3B,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YACpC,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YAE1B,+BAA+B;YAC/B,IAAI,WAAW,KAAK,GAAG,EAAE,CAAC;gBACxB,SAAS;YACX,CAAC;YAED,uBAAuB;YACvB,IAAI,WAAW,KAAK,MAAM,EAAE,CAAC;gBAC3B,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+EAA+E;IAC/E,gBAAgB;IAChB,+EAA+E;IAE/E;;OAEG;IACK,kBAAkB;QACxB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QAExC,IAAI,SAAS,KAAK,KAAK,EAAE,CAAC;YACxB,mDAAmD;YACnD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACnE,CAAC;QAED,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE,CAAC;YAClC,OAAO;gBACL,QAAQ,EAAE,SAAS,CAAC,QAAQ,IAAI,kBAAkB,CAAC,QAAQ;gBAC3D,WAAW,EAAE,SAAS,CAAC,WAAW,IAAI,kBAAkB,CAAC,WAAW;aACrE,CAAC;QACJ,CAAC;QAED,OAAO,kBAAkB,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACK,cAAc,CAAC,EAAU;QAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAE1C,IAAI,CAAC,KAAK,IAAI,GAAG,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YACnC,qDAAqD;YACrD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,EAAE;gBAC1B,KAAK,EAAE,CAAC;gBACR,OAAO,EAAE,GAAG,GAAG,MAAM,CAAC,QAAQ;aAC/B,CAAC,CAAC;YACH,OAAO,IAAI,CAAC;QACd,CAAC;QAED,oBAAoB;QACpB,KAAK,CAAC,KAAK,EAAE,CAAC;QAEd,sBAAsB;QACtB,IAAI,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC;YACrC,OAAO,KAAK,CAAC;QACf,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,qBAAqB,CAAC,EAAU;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,KAAK;YAAE,OAAO,CAAC,CAAC;QAErB,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC7C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACK,qBAAqB;QAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,CAAC;YACxD,IAAI,GAAG,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAC/B,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;QAED,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,cAAc,OAAO,6BAA6B,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;CACF,CAAA;AAxUY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;IAgBR,WAAA,IAAA,eAAM,EAAC,iCAAe,CAAC,CAAA;;GAff,aAAa,CAwUzB"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Request, Response } from 'express';
|
|
2
|
+
import { NestLensConfig } from '../nestlens.config';
|
|
3
|
+
export declare class DashboardController {
|
|
4
|
+
private readonly config;
|
|
5
|
+
private readonly dashboardPath;
|
|
6
|
+
constructor(config: NestLensConfig);
|
|
7
|
+
serveDashboard(req: Request, res: Response): void;
|
|
8
|
+
serveAssets(filename: string, res: Response): void;
|
|
9
|
+
serveStaticFile(filename: string, res: Response): void;
|
|
10
|
+
serveRequestsRoute(res: Response): void;
|
|
11
|
+
serveQueriesRoute(res: Response): void;
|
|
12
|
+
serveExceptionsRoute(res: Response): void;
|
|
13
|
+
serveLogsRoute(res: Response): void;
|
|
14
|
+
serveEntryDetailRoute(res: Response): void;
|
|
15
|
+
serveEventsRoute(res: Response): void;
|
|
16
|
+
serveEventDetailRoute(res: Response): void;
|
|
17
|
+
serveJobsRoute(res: Response): void;
|
|
18
|
+
serveJobDetailRoute(res: Response): void;
|
|
19
|
+
serveCacheRoute(res: Response): void;
|
|
20
|
+
serveCacheDetailRoute(res: Response): void;
|
|
21
|
+
serveMailRoute(res: Response): void;
|
|
22
|
+
serveMailDetailRoute(res: Response): void;
|
|
23
|
+
serveScheduleRoute(res: Response): void;
|
|
24
|
+
serveScheduleDetailRoute(res: Response): void;
|
|
25
|
+
serveHttpClientRoute(res: Response): void;
|
|
26
|
+
serveHttpClientDetailRoute(res: Response): void;
|
|
27
|
+
serveRequestDetailRoute(res: Response): void;
|
|
28
|
+
serveQueryDetailRoute(res: Response): void;
|
|
29
|
+
serveExceptionDetailRoute(res: Response): void;
|
|
30
|
+
serveLogDetailRoute(res: Response): void;
|
|
31
|
+
serveRedisRoute(res: Response): void;
|
|
32
|
+
serveRedisDetailRoute(res: Response): void;
|
|
33
|
+
serveModelsRoute(res: Response): void;
|
|
34
|
+
serveModelDetailRoute(res: Response): void;
|
|
35
|
+
serveNotificationsRoute(res: Response): void;
|
|
36
|
+
serveNotificationDetailRoute(res: Response): void;
|
|
37
|
+
serveViewsRoute(res: Response): void;
|
|
38
|
+
serveViewDetailRoute(res: Response): void;
|
|
39
|
+
serveCommandsRoute(res: Response): void;
|
|
40
|
+
serveCommandDetailRoute(res: Response): void;
|
|
41
|
+
serveGatesRoute(res: Response): void;
|
|
42
|
+
serveGateDetailRoute(res: Response): void;
|
|
43
|
+
serveBatchesRoute(res: Response): void;
|
|
44
|
+
serveBatchDetailRoute(res: Response): void;
|
|
45
|
+
serveDumpsRoute(res: Response): void;
|
|
46
|
+
serveDumpDetailRoute(res: Response): void;
|
|
47
|
+
private serveIndexHtml;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=dashboard.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboard.controller.d.ts","sourceRoot":"","sources":["../../src/api/dashboard.controller.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAG5C,OAAO,EAAE,cAAc,EAAmB,MAAM,oBAAoB,CAAC;AAGrE,qBAEa,mBAAmB;IAK5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJzB,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;gBAIpB,MAAM,EAAE,cAAc;IAOzC,cAAc,CAAQ,GAAG,EAAE,OAAO,EAAS,GAAG,EAAE,QAAQ;IAexD,WAAW,CAAoB,QAAQ,EAAE,MAAM,EAAS,GAAG,EAAE,QAAQ;IAWrE,eAAe,CAAoB,QAAQ,EAAE,MAAM,EAAS,GAAG,EAAE,QAAQ;IAWzE,kBAAkB,CAAQ,GAAG,EAAE,QAAQ;IAKvC,iBAAiB,CAAQ,GAAG,EAAE,QAAQ;IAKtC,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAKzC,cAAc,CAAQ,GAAG,EAAE,QAAQ;IAKnC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,gBAAgB,CAAQ,GAAG,EAAE,QAAQ;IAKrC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,cAAc,CAAQ,GAAG,EAAE,QAAQ;IAKnC,mBAAmB,CAAQ,GAAG,EAAE,QAAQ;IAKxC,eAAe,CAAQ,GAAG,EAAE,QAAQ;IAKpC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,cAAc,CAAQ,GAAG,EAAE,QAAQ;IAKnC,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAKzC,kBAAkB,CAAQ,GAAG,EAAE,QAAQ;IAKvC,wBAAwB,CAAQ,GAAG,EAAE,QAAQ;IAK7C,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAKzC,0BAA0B,CAAQ,GAAG,EAAE,QAAQ;IAK/C,uBAAuB,CAAQ,GAAG,EAAE,QAAQ;IAK5C,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,yBAAyB,CAAQ,GAAG,EAAE,QAAQ;IAK9C,mBAAmB,CAAQ,GAAG,EAAE,QAAQ;IAMxC,eAAe,CAAQ,GAAG,EAAE,QAAQ;IAKpC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,gBAAgB,CAAQ,GAAG,EAAE,QAAQ;IAKrC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,uBAAuB,CAAQ,GAAG,EAAE,QAAQ;IAK5C,4BAA4B,CAAQ,GAAG,EAAE,QAAQ;IAKjD,eAAe,CAAQ,GAAG,EAAE,QAAQ;IAKpC,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAKzC,kBAAkB,CAAQ,GAAG,EAAE,QAAQ;IAKvC,uBAAuB,CAAQ,GAAG,EAAE,QAAQ;IAK5C,eAAe,CAAQ,GAAG,EAAE,QAAQ;IAKpC,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAKzC,iBAAiB,CAAQ,GAAG,EAAE,QAAQ;IAKtC,qBAAqB,CAAQ,GAAG,EAAE,QAAQ;IAK1C,eAAe,CAAQ,GAAG,EAAE,QAAQ;IAKpC,oBAAoB,CAAQ,GAAG,EAAE,QAAQ;IAIzC,OAAO,CAAC,cAAc;CAQvB"}
|