@resolveio/server-lib 22.3.22 → 22.3.23
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/.nodemon.json +5 -0
- package/.vscode/settings.json +21 -0
- package/AGENTS.md +189 -0
- package/README.md +22 -0
- package/build_package.sh +5 -0
- package/compileDTS.pl +64 -0
- package/docs/ai-assistant-nightly-eval.md +65 -0
- package/docs/ai-assistant-preflight-checklist.md +23 -0
- package/docs/ai-assistant-report-builder-bridge-playbook.md +115 -0
- package/eslint-plugin-custom/index.js +7 -0
- package/eslint-plugin-custom/rules/no-filter-zero-index.js +44 -0
- package/eslint.config.js +103 -0
- package/gulpfile.js +216 -0
- package/methodAndPublicationListGenerator.py +344 -0
- package/mongodbensurers.js +2 -0
- package/mongostop.js +3 -0
- package/package.json +1 -1
- package/scripts/cleanup-bypassed-callmethod-logs.js +616 -0
- package/settings.development.json +25 -0
- package/settings.development.redacted.json +25 -0
- package/src/.env +12 -0
- package/src/ai/assistant-core-heuristics.ts +379 -0
- package/src/ai/resolveio-platform-intelligence-memory-corpus.ts +185 -0
- package/src/ai/resolveio-platform-intelligence-memory.ts +325 -0
- package/{ai/resolveio-platform-intelligence-types.d.ts → src/ai/resolveio-platform-intelligence-types.ts} +20 -15
- package/src/ai/resolveio-platform-intelligence.ts +462 -0
- package/src/client-server-app.ts +12 -0
- package/src/collections/ai-terminal-conversation.collection.ts +91 -0
- package/src/collections/ai-terminal-issue-report.collection.ts +99 -0
- package/src/collections/ai-terminal-message.collection.ts +77 -0
- package/src/collections/app-setting.collection.ts +104 -0
- package/src/collections/app-status.collection.ts +58 -0
- package/src/collections/communication-metric.collection.ts +84 -0
- package/src/collections/counter.collection.ts +56 -0
- package/src/collections/cron-job-history.collection.ts +94 -0
- package/src/collections/cron-job.collection.ts +92 -0
- package/src/collections/customer-notification.collection.ts +131 -0
- package/src/collections/customer-portal-password.collection.ts +76 -0
- package/src/collections/email-history.collection.ts +127 -0
- package/src/collections/email-verified.collection.ts +62 -0
- package/src/collections/file.collection.ts +74 -0
- package/src/collections/flag-update.collection.ts +57 -0
- package/src/collections/flag.collection.ts +57 -0
- package/src/collections/log-method-latency.collection.ts +77 -0
- package/src/collections/log-subscription.collection.ts +80 -0
- package/src/collections/log.collection.ts +93 -0
- package/src/collections/logged-in-users.collection.ts +67 -0
- package/src/collections/monitor-cpu.collection.ts +65 -0
- package/src/collections/monitor-function.collection.ts +74 -0
- package/src/collections/monitor-memory.collection.ts +77 -0
- package/src/collections/monitor-mongo.collection.ts +71 -0
- package/src/collections/notification.collection.ts +57 -0
- package/src/collections/openai-usage-ledger.collection.ts +77 -0
- package/src/collections/report-builder-dashboard-builder.collection.ts +109 -0
- package/src/collections/report-builder-library.collection.ts +89 -0
- package/src/collections/report-builder-report.collection.ts +184 -0
- package/src/collections/user-group.collection.ts +89 -0
- package/src/collections/user-guide.collection.ts +57 -0
- package/src/collections/user.collection.ts +181 -0
- package/src/cron/cron.ts +117 -0
- package/src/fixtures/cron-jobs.ts +95 -0
- package/src/fixtures/init.ts +35 -0
- package/src/http/auth.ts +764 -0
- package/src/http/health.ts +7 -0
- package/src/http/home.ts +90 -0
- package/src/http/slow-query-publication.ts +49 -0
- package/src/index.ts +1 -0
- package/src/managers/ai-assistant-codex-manager.manager.ts +1131 -0
- package/src/managers/communication-metric.manager.ts +82 -0
- package/src/managers/cron.manager.ts +333 -0
- package/src/managers/customer-notification-content.manager.ts +236 -0
- package/src/managers/diagnostic-manager-bootstrap.ts +165 -0
- package/src/managers/error-auto-fix.manager.ts +2767 -0
- package/src/managers/local-log.manager.ts +113 -0
- package/src/managers/method.manager.ts +1827 -0
- package/src/managers/mongo.manager.ts +4575 -0
- package/src/managers/monitor.manager.ts +507 -0
- package/src/managers/openai-usage-ledger.manager.ts +116 -0
- package/src/managers/slow-query-verifier.manager.ts +3590 -0
- package/src/managers/slow-query.manager.ts +519 -0
- package/src/managers/subscription.manager.ts +3128 -0
- package/src/managers/websocket.manager.ts +746 -0
- package/src/managers/worker-dispatcher.manager.ts +1360 -0
- package/src/managers/worker-server.manager.ts +536 -0
- package/src/methods/accounts.ts +532 -0
- package/src/methods/ai-terminal.ts +22943 -0
- package/src/methods/app-settings.ts +114 -0
- package/src/methods/aws.ts +649 -0
- package/src/methods/collections.ts +641 -0
- package/src/methods/counters.ts +69 -0
- package/src/methods/cron-jobs.ts +2614 -0
- package/src/methods/customer-notifications.ts +458 -0
- package/src/methods/diagnostics.ts +616 -0
- package/src/methods/flag-updates.ts +7 -0
- package/src/methods/flags.ts +7 -0
- package/src/methods/logs.ts +657 -0
- package/src/methods/mongo-explorer.ts +1880 -0
- package/src/methods/monitor.ts +540 -0
- package/src/methods/pdf.ts +1236 -0
- package/src/methods/publications.ts +129 -0
- package/src/methods/report-builder.ts +3300 -0
- package/src/methods/support.ts +335 -0
- package/src/models/ai-terminal-conversation.model.ts +19 -0
- package/src/models/ai-terminal-issue-report.model.ts +21 -0
- package/src/models/ai-terminal-message.model.ts +24 -0
- package/src/models/app-setting.model.ts +17 -0
- package/{models/app-status.model.d.ts → src/models/app-status.model.ts} +3 -2
- package/{models/billing-logged-in-users.model.d.ts → src/models/billing-logged-in-users.model.ts} +5 -4
- package/src/models/collection-document.model.ts +24 -0
- package/src/models/communication-metric.model.ts +23 -0
- package/{models/counter.model.d.ts → src/models/counter.model.ts} +4 -3
- package/src/models/cron-job-history.model.ts +16 -0
- package/src/models/cron-job.model.ts +15 -0
- package/src/models/customer-notification.model.ts +28 -0
- package/src/models/customer-portal-password.model.ts +12 -0
- package/src/models/dialog.model.ts +25 -0
- package/{models/email-history.model.js → src/models/email-history.model.ts} +35 -4
- package/{models/email-verified.model.d.ts → src/models/email-verified.model.ts} +6 -5
- package/{models/file.model.d.ts → src/models/file.model.ts} +8 -7
- package/{models/flag-update.model.d.ts → src/models/flag-update.model.ts} +4 -3
- package/{models/flag.model.d.ts → src/models/flag.model.ts} +4 -3
- package/src/models/log-method-latency.model.ts +11 -0
- package/{models/log-subscription.model.d.ts → src/models/log-subscription.model.ts} +11 -9
- package/src/models/log.model.ts +19 -0
- package/{models/logged-in-users.model.d.ts → src/models/logged-in-users.model.ts} +6 -5
- package/{models/method-response.model.d.ts → src/models/method-response.model.ts} +7 -6
- package/src/models/method.model.ts +25 -0
- package/{models/monitor-cpu.model.d.ts → src/models/monitor-cpu.model.ts} +9 -7
- package/src/models/monitor-function.model.ts +16 -0
- package/src/models/monitor-memory.model.ts +17 -0
- package/src/models/monitor-mongo.model.ts +15 -0
- package/{models/notification.model.d.ts → src/models/notification.model.ts} +6 -4
- package/src/models/openai-usage-ledger.model.ts +16 -0
- package/src/models/pagination.model.ts +35 -0
- package/src/models/permission.model.ts +14 -0
- package/src/models/report-builder-dashboard-builder.model.ts +29 -0
- package/src/models/report-builder-library.model.ts +20 -0
- package/src/models/report-builder-report.model.ts +136 -0
- package/src/models/report-builder.model.ts +68 -0
- package/src/models/select-data-label.model.ts +9 -0
- package/src/models/server-message.model.ts +31 -0
- package/src/models/slow-query-report.model.ts +23 -0
- package/src/models/subscription.model.ts +73 -0
- package/src/models/support-ticket.model.ts +104 -0
- package/src/models/user-group.model.ts +24 -0
- package/{models/user-guide.model.d.ts → src/models/user-guide.model.ts} +5 -4
- package/src/models/user.model.ts +96 -0
- package/src/private/images/ResolveIO.png +0 -0
- package/src/publications/ai-terminal.ts +73 -0
- package/src/publications/app-settings.ts +25 -0
- package/src/publications/app-status.ts +13 -0
- package/src/publications/cron-jobs.ts +40 -0
- package/src/publications/customer-notifications.ts +101 -0
- package/src/publications/files.ts +33 -0
- package/src/publications/flags-update.ts +19 -0
- package/src/publications/flags.ts +19 -0
- package/src/publications/logs.ts +163 -0
- package/src/publications/notifications.ts +13 -0
- package/src/publications/report-builder-dashboard-builders.ts +39 -0
- package/src/publications/report-builder-libraries.ts +41 -0
- package/src/publications/report-builder-reports.ts +47 -0
- package/src/publications/super-admin.ts +13 -0
- package/src/publications/user-groups.ts +12 -0
- package/src/publications/user-guides.ts +12 -0
- package/src/resolveio-server-app.ts +617 -0
- package/src/server-app.ts +3354 -0
- package/src/services/codex-client.ts +1223 -0
- package/src/services/openai-client.ts +265 -0
- package/src/types/error-report.ts +26 -0
- package/src/types/js-tiktoken.d.ts +11 -0
- package/src/types/slow-query-report.ts +28 -0
- package/src/util/ai-qa-policy.ts +799 -0
- package/src/util/common.ts +649 -0
- package/src/util/customer-portal-password.ts +183 -0
- package/src/util/error-reporter.ts +332 -0
- package/src/util/error-tracking.ts +79 -0
- package/src/util/report-builder-unwinds.ts +180 -0
- package/src/util/schema-report-builder.ts +448 -0
- package/src/util/slow-query-reporter.ts +216 -0
- package/src/util/subscription-dependency-context.ts +1096 -0
- package/src/util/tokenizer.ts +38 -0
- package/src/workers/codex-runner.worker.ts +142 -0
- package/start_server.sh +5 -0
- package/tests/ai-assistant-corpus-build.ts +484 -0
- package/tests/ai-assistant-corpus-replay-e2e.ts +774 -0
- package/tests/ai-assistant-data-parity-e2e.ts +1989 -0
- package/tests/ai-assistant-eval-triage.ts +831 -0
- package/tests/ai-assistant-openai-e2e.ts +1061 -0
- package/tests/ai-assistant-openai-git-e2e.ts +155 -0
- package/tests/ai-assistant-preflight-matrix.ts +215 -0
- package/tests/ai-assistant-routing-eval.test.ts +560 -0
- package/tests/ai-assistant-snf-live-eval.ts +975 -0
- package/tests/ai-assistant-utils.test.ts +2860 -0
- package/tests/ai-runner-contract.test.ts +119 -0
- package/tests/error-reporter.test.ts +145 -0
- package/tests/report-builder-linking.test.ts +79 -0
- package/tests/resolveio-platform-intelligence.test.ts +352 -0
- package/tests/server-app-cron-owner.test.ts +127 -0
- package/tests/subscription-connect-race.test.ts +158 -0
- package/tests/subscription-dependency-context.test.ts +324 -0
- package/tests/subscription-manager-collection-tracking.test.ts +86 -0
- package/tests/subscription-manager-invalidation.test.ts +86 -0
- package/tsconfig.json +34 -0
- package/ai/assistant-core-heuristics.d.ts +0 -11
- package/ai/assistant-core-heuristics.js +0 -356
- package/ai/assistant-core-heuristics.js.map +0 -1
- package/ai/resolveio-platform-intelligence-memory-corpus.d.ts +0 -3
- package/ai/resolveio-platform-intelligence-memory-corpus.js +0 -214
- package/ai/resolveio-platform-intelligence-memory-corpus.js.map +0 -1
- package/ai/resolveio-platform-intelligence-memory.d.ts +0 -20
- package/ai/resolveio-platform-intelligence-memory.js +0 -341
- package/ai/resolveio-platform-intelligence-memory.js.map +0 -1
- package/ai/resolveio-platform-intelligence-types.js +0 -4
- package/ai/resolveio-platform-intelligence-types.js.map +0 -1
- package/ai/resolveio-platform-intelligence.d.ts +0 -6
- package/ai/resolveio-platform-intelligence.js +0 -463
- package/ai/resolveio-platform-intelligence.js.map +0 -1
- package/client-server-app.d.ts +0 -1
- package/client-server-app.js +0 -68
- package/client-server-app.js.map +0 -1
- package/collections/ai-terminal-conversation.collection.d.ts +0 -2
- package/collections/ai-terminal-conversation.collection.js +0 -140
- package/collections/ai-terminal-conversation.collection.js.map +0 -1
- package/collections/ai-terminal-issue-report.collection.d.ts +0 -2
- package/collections/ai-terminal-issue-report.collection.js +0 -148
- package/collections/ai-terminal-issue-report.collection.js.map +0 -1
- package/collections/ai-terminal-message.collection.d.ts +0 -2
- package/collections/ai-terminal-message.collection.js +0 -121
- package/collections/ai-terminal-message.collection.js.map +0 -1
- package/collections/app-setting.collection.d.ts +0 -3
- package/collections/app-setting.collection.js +0 -103
- package/collections/app-setting.collection.js.map +0 -1
- package/collections/app-status.collection.d.ts +0 -3
- package/collections/app-status.collection.js +0 -57
- package/collections/app-status.collection.js.map +0 -1
- package/collections/communication-metric.collection.d.ts +0 -2
- package/collections/communication-metric.collection.js +0 -133
- package/collections/communication-metric.collection.js.map +0 -1
- package/collections/counter.collection.d.ts +0 -3
- package/collections/counter.collection.js +0 -56
- package/collections/counter.collection.js.map +0 -1
- package/collections/cron-job-history.collection.d.ts +0 -3
- package/collections/cron-job-history.collection.js +0 -137
- package/collections/cron-job-history.collection.js.map +0 -1
- package/collections/cron-job.collection.d.ts +0 -3
- package/collections/cron-job.collection.js +0 -92
- package/collections/cron-job.collection.js.map +0 -1
- package/collections/customer-notification.collection.d.ts +0 -3
- package/collections/customer-notification.collection.js +0 -130
- package/collections/customer-notification.collection.js.map +0 -1
- package/collections/customer-portal-password.collection.d.ts +0 -3
- package/collections/customer-portal-password.collection.js +0 -75
- package/collections/customer-portal-password.collection.js.map +0 -1
- package/collections/email-history.collection.d.ts +0 -3
- package/collections/email-history.collection.js +0 -127
- package/collections/email-history.collection.js.map +0 -1
- package/collections/email-verified.collection.d.ts +0 -3
- package/collections/email-verified.collection.js +0 -62
- package/collections/email-verified.collection.js.map +0 -1
- package/collections/file.collection.d.ts +0 -3
- package/collections/file.collection.js +0 -74
- package/collections/file.collection.js.map +0 -1
- package/collections/flag-update.collection.d.ts +0 -3
- package/collections/flag-update.collection.js +0 -57
- package/collections/flag-update.collection.js.map +0 -1
- package/collections/flag.collection.d.ts +0 -3
- package/collections/flag.collection.js +0 -57
- package/collections/flag.collection.js.map +0 -1
- package/collections/log-method-latency.collection.d.ts +0 -3
- package/collections/log-method-latency.collection.js +0 -77
- package/collections/log-method-latency.collection.js.map +0 -1
- package/collections/log-subscription.collection.d.ts +0 -3
- package/collections/log-subscription.collection.js +0 -80
- package/collections/log-subscription.collection.js.map +0 -1
- package/collections/log.collection.d.ts +0 -3
- package/collections/log.collection.js +0 -93
- package/collections/log.collection.js.map +0 -1
- package/collections/logged-in-users.collection.d.ts +0 -3
- package/collections/logged-in-users.collection.js +0 -67
- package/collections/logged-in-users.collection.js.map +0 -1
- package/collections/monitor-cpu.collection.d.ts +0 -3
- package/collections/monitor-cpu.collection.js +0 -65
- package/collections/monitor-cpu.collection.js.map +0 -1
- package/collections/monitor-function.collection.d.ts +0 -3
- package/collections/monitor-function.collection.js +0 -74
- package/collections/monitor-function.collection.js.map +0 -1
- package/collections/monitor-memory.collection.d.ts +0 -3
- package/collections/monitor-memory.collection.js +0 -77
- package/collections/monitor-memory.collection.js.map +0 -1
- package/collections/monitor-mongo.collection.d.ts +0 -3
- package/collections/monitor-mongo.collection.js +0 -71
- package/collections/monitor-mongo.collection.js.map +0 -1
- package/collections/notification.collection.d.ts +0 -3
- package/collections/notification.collection.js +0 -57
- package/collections/notification.collection.js.map +0 -1
- package/collections/openai-usage-ledger.collection.d.ts +0 -2
- package/collections/openai-usage-ledger.collection.js +0 -124
- package/collections/openai-usage-ledger.collection.js.map +0 -1
- package/collections/report-builder-dashboard-builder.collection.d.ts +0 -3
- package/collections/report-builder-dashboard-builder.collection.js +0 -109
- package/collections/report-builder-dashboard-builder.collection.js.map +0 -1
- package/collections/report-builder-library.collection.d.ts +0 -3
- package/collections/report-builder-library.collection.js +0 -87
- package/collections/report-builder-library.collection.js.map +0 -1
- package/collections/report-builder-report.collection.d.ts +0 -4
- package/collections/report-builder-report.collection.js +0 -184
- package/collections/report-builder-report.collection.js.map +0 -1
- package/collections/user-group.collection.d.ts +0 -4
- package/collections/user-group.collection.js +0 -89
- package/collections/user-group.collection.js.map +0 -1
- package/collections/user-guide.collection.d.ts +0 -3
- package/collections/user-guide.collection.js +0 -57
- package/collections/user-guide.collection.js.map +0 -1
- package/collections/user.collection.d.ts +0 -4
- package/collections/user.collection.js +0 -180
- package/collections/user.collection.js.map +0 -1
- package/cron/cron.d.ts +0 -14
- package/cron/cron.js +0 -216
- package/cron/cron.js.map +0 -1
- package/fixtures/cron-jobs.d.ts +0 -1
- package/fixtures/cron-jobs.js +0 -150
- package/fixtures/cron-jobs.js.map +0 -1
- package/fixtures/init.d.ts +0 -1
- package/fixtures/init.js +0 -91
- package/fixtures/init.js.map +0 -1
- package/http/auth.d.ts +0 -2
- package/http/auth.js +0 -906
- package/http/auth.js.map +0 -1
- package/http/health.d.ts +0 -1
- package/http/health.js +0 -11
- package/http/health.js.map +0 -1
- package/http/home.d.ts +0 -1
- package/http/home.js +0 -134
- package/http/home.js.map +0 -1
- package/http/slow-query-publication.d.ts +0 -2
- package/http/slow-query-publication.js +0 -99
- package/http/slow-query-publication.js.map +0 -1
- package/index.d.ts +0 -1
- package/index.js +0 -19
- package/index.js.map +0 -1
- package/managers/ai-assistant-codex-manager.manager.d.ts +0 -67
- package/managers/ai-assistant-codex-manager.manager.js +0 -1113
- package/managers/ai-assistant-codex-manager.manager.js.map +0 -1
- package/managers/communication-metric.manager.d.ts +0 -16
- package/managers/communication-metric.manager.js +0 -134
- package/managers/communication-metric.manager.js.map +0 -1
- package/managers/cron.manager.d.ts +0 -20
- package/managers/cron.manager.js +0 -534
- package/managers/cron.manager.js.map +0 -1
- package/managers/customer-notification-content.manager.d.ts +0 -55
- package/managers/customer-notification-content.manager.js +0 -158
- package/managers/customer-notification-content.manager.js.map +0 -1
- package/managers/diagnostic-manager-bootstrap.d.ts +0 -9
- package/managers/diagnostic-manager-bootstrap.js +0 -260
- package/managers/diagnostic-manager-bootstrap.js.map +0 -1
- package/managers/error-auto-fix.manager.d.ts +0 -149
- package/managers/error-auto-fix.manager.js +0 -3064
- package/managers/error-auto-fix.manager.js.map +0 -1
- package/managers/local-log.manager.d.ts +0 -18
- package/managers/local-log.manager.js +0 -88
- package/managers/local-log.manager.js.map +0 -1
- package/managers/method.manager.d.ts +0 -83
- package/managers/method.manager.js +0 -1941
- package/managers/method.manager.js.map +0 -1
- package/managers/mongo.manager.d.ts +0 -224
- package/managers/mongo.manager.js +0 -5000
- package/managers/mongo.manager.js.map +0 -1
- package/managers/monitor.manager.d.ts +0 -70
- package/managers/monitor.manager.js +0 -550
- package/managers/monitor.manager.js.map +0 -1
- package/managers/openai-usage-ledger.manager.d.ts +0 -15
- package/managers/openai-usage-ledger.manager.js +0 -144
- package/managers/openai-usage-ledger.manager.js.map +0 -1
- package/managers/slow-query-verifier.manager.d.ts +0 -144
- package/managers/slow-query-verifier.manager.js +0 -3857
- package/managers/slow-query-verifier.manager.js.map +0 -1
- package/managers/slow-query.manager.d.ts +0 -28
- package/managers/slow-query.manager.js +0 -468
- package/managers/slow-query.manager.js.map +0 -1
- package/managers/subscription.manager.d.ts +0 -169
- package/managers/subscription.manager.js +0 -3434
- package/managers/subscription.manager.js.map +0 -1
- package/managers/websocket.manager.d.ts +0 -73
- package/managers/websocket.manager.js +0 -673
- package/managers/websocket.manager.js.map +0 -1
- package/managers/worker-dispatcher.manager.d.ts +0 -120
- package/managers/worker-dispatcher.manager.js +0 -1266
- package/managers/worker-dispatcher.manager.js.map +0 -1
- package/managers/worker-server.manager.d.ts +0 -35
- package/managers/worker-server.manager.js +0 -582
- package/managers/worker-server.manager.js.map +0 -1
- package/methods/accounts.d.ts +0 -2
- package/methods/accounts.js +0 -624
- package/methods/accounts.js.map +0 -1
- package/methods/ai-terminal.d.ts +0 -322
- package/methods/ai-terminal.js +0 -22699
- package/methods/ai-terminal.js.map +0 -1
- package/methods/app-settings.d.ts +0 -2
- package/methods/app-settings.js +0 -169
- package/methods/app-settings.js.map +0 -1
- package/methods/aws.d.ts +0 -2
- package/methods/aws.js +0 -877
- package/methods/aws.js.map +0 -1
- package/methods/collections.d.ts +0 -2
- package/methods/collections.js +0 -719
- package/methods/collections.js.map +0 -1
- package/methods/counters.d.ts +0 -2
- package/methods/counters.js +0 -113
- package/methods/counters.js.map +0 -1
- package/methods/cron-jobs.d.ts +0 -2
- package/methods/cron-jobs.js +0 -2475
- package/methods/cron-jobs.js.map +0 -1
- package/methods/customer-notifications.d.ts +0 -2
- package/methods/customer-notifications.js +0 -528
- package/methods/customer-notifications.js.map +0 -1
- package/methods/diagnostics.d.ts +0 -2
- package/methods/diagnostics.js +0 -703
- package/methods/diagnostics.js.map +0 -1
- package/methods/flag-updates.d.ts +0 -2
- package/methods/flag-updates.js +0 -8
- package/methods/flag-updates.js.map +0 -1
- package/methods/flags.d.ts +0 -2
- package/methods/flags.js +0 -8
- package/methods/flags.js.map +0 -1
- package/methods/logs.d.ts +0 -2
- package/methods/logs.js +0 -751
- package/methods/logs.js.map +0 -1
- package/methods/mongo-explorer.d.ts +0 -2
- package/methods/mongo-explorer.js +0 -1808
- package/methods/mongo-explorer.js.map +0 -1
- package/methods/monitor.d.ts +0 -2
- package/methods/monitor.js +0 -543
- package/methods/monitor.js.map +0 -1
- package/methods/pdf.d.ts +0 -2
- package/methods/pdf.js +0 -1216
- package/methods/pdf.js.map +0 -1
- package/methods/publications.d.ts +0 -1
- package/methods/publications.js +0 -183
- package/methods/publications.js.map +0 -1
- package/methods/report-builder.d.ts +0 -2
- package/methods/report-builder.js +0 -3094
- package/methods/report-builder.js.map +0 -1
- package/methods/support.d.ts +0 -2
- package/methods/support.js +0 -430
- package/methods/support.js.map +0 -1
- package/models/ai-terminal-conversation.model.d.ts +0 -17
- package/models/ai-terminal-conversation.model.js +0 -4
- package/models/ai-terminal-conversation.model.js.map +0 -1
- package/models/ai-terminal-issue-report.model.d.ts +0 -19
- package/models/ai-terminal-issue-report.model.js +0 -4
- package/models/ai-terminal-issue-report.model.js.map +0 -1
- package/models/ai-terminal-message.model.d.ts +0 -22
- package/models/ai-terminal-message.model.js +0 -4
- package/models/ai-terminal-message.model.js.map +0 -1
- package/models/app-setting.model.d.ts +0 -16
- package/models/app-setting.model.js +0 -4
- package/models/app-setting.model.js.map +0 -1
- package/models/app-status.model.js +0 -4
- package/models/app-status.model.js.map +0 -1
- package/models/billing-logged-in-users.model.js +0 -4
- package/models/billing-logged-in-users.model.js.map +0 -1
- package/models/collection-document.model.d.ts +0 -21
- package/models/collection-document.model.js +0 -4
- package/models/collection-document.model.js.map +0 -1
- package/models/communication-metric.model.d.ts +0 -20
- package/models/communication-metric.model.js +0 -4
- package/models/communication-metric.model.js.map +0 -1
- package/models/counter.model.js +0 -4
- package/models/counter.model.js.map +0 -1
- package/models/cron-job-history.model.d.ts +0 -15
- package/models/cron-job-history.model.js +0 -4
- package/models/cron-job-history.model.js.map +0 -1
- package/models/cron-job.model.d.ts +0 -14
- package/models/cron-job.model.js +0 -4
- package/models/cron-job.model.js.map +0 -1
- package/models/customer-notification.model.d.ts +0 -26
- package/models/customer-notification.model.js +0 -4
- package/models/customer-notification.model.js.map +0 -1
- package/models/customer-portal-password.model.d.ts +0 -11
- package/models/customer-portal-password.model.js +0 -4
- package/models/customer-portal-password.model.js.map +0 -1
- package/models/dialog.model.d.ts +0 -23
- package/models/dialog.model.js +0 -4
- package/models/dialog.model.js.map +0 -1
- package/models/email-history.model.d.ts +0 -31
- package/models/email-history.model.js.map +0 -1
- package/models/email-verified.model.js +0 -4
- package/models/email-verified.model.js.map +0 -1
- package/models/file.model.js +0 -4
- package/models/file.model.js.map +0 -1
- package/models/flag-update.model.js +0 -4
- package/models/flag-update.model.js.map +0 -1
- package/models/flag.model.js +0 -4
- package/models/flag.model.js.map +0 -1
- package/models/log-method-latency.model.d.ts +0 -10
- package/models/log-method-latency.model.js +0 -4
- package/models/log-method-latency.model.js.map +0 -1
- package/models/log-subscription.model.js +0 -4
- package/models/log-subscription.model.js.map +0 -1
- package/models/log.model.d.ts +0 -17
- package/models/log.model.js +0 -4
- package/models/log.model.js.map +0 -1
- package/models/logged-in-users.model.js +0 -4
- package/models/logged-in-users.model.js.map +0 -1
- package/models/method-response.model.js +0 -4
- package/models/method-response.model.js.map +0 -1
- package/models/method.model.d.ts +0 -26
- package/models/method.model.js +0 -4
- package/models/method.model.js.map +0 -1
- package/models/monitor-cpu.model.js +0 -4
- package/models/monitor-cpu.model.js.map +0 -1
- package/models/monitor-function.model.d.ts +0 -14
- package/models/monitor-function.model.js +0 -4
- package/models/monitor-function.model.js.map +0 -1
- package/models/monitor-memory.model.d.ts +0 -15
- package/models/monitor-memory.model.js +0 -4
- package/models/monitor-memory.model.js.map +0 -1
- package/models/monitor-mongo.model.d.ts +0 -13
- package/models/monitor-mongo.model.js +0 -4
- package/models/monitor-mongo.model.js.map +0 -1
- package/models/notification.model.js +0 -4
- package/models/notification.model.js.map +0 -1
- package/models/openai-usage-ledger.model.d.ts +0 -15
- package/models/openai-usage-ledger.model.js +0 -4
- package/models/openai-usage-ledger.model.js.map +0 -1
- package/models/pagination.model.d.ts +0 -11
- package/models/pagination.model.js +0 -28
- package/models/pagination.model.js.map +0 -1
- package/models/permission.model.d.ts +0 -12
- package/models/permission.model.js +0 -4
- package/models/permission.model.js.map +0 -1
- package/models/report-builder-dashboard-builder.model.d.ts +0 -25
- package/models/report-builder-dashboard-builder.model.js +0 -4
- package/models/report-builder-dashboard-builder.model.js.map +0 -1
- package/models/report-builder-library.model.d.ts +0 -17
- package/models/report-builder-library.model.js +0 -4
- package/models/report-builder-library.model.js.map +0 -1
- package/models/report-builder-report.model.d.ts +0 -121
- package/models/report-builder-report.model.js +0 -4
- package/models/report-builder-report.model.js.map +0 -1
- package/models/report-builder.model.d.ts +0 -61
- package/models/report-builder.model.js +0 -4
- package/models/report-builder.model.js.map +0 -1
- package/models/select-data-label.model.d.ts +0 -9
- package/models/select-data-label.model.js +0 -4
- package/models/select-data-label.model.js.map +0 -1
- package/models/server-message.model.d.ts +0 -32
- package/models/server-message.model.js +0 -4
- package/models/server-message.model.js.map +0 -1
- package/models/slow-query-report.model.d.ts +0 -23
- package/models/slow-query-report.model.js +0 -4
- package/models/slow-query-report.model.js.map +0 -1
- package/models/subscription.model.d.ts +0 -31
- package/models/subscription.model.js +0 -4
- package/models/subscription.model.js.map +0 -1
- package/models/support-ticket.model.d.ts +0 -87
- package/models/support-ticket.model.js +0 -4
- package/models/support-ticket.model.js.map +0 -1
- package/models/user-group.model.d.ts +0 -20
- package/models/user-group.model.js +0 -4
- package/models/user-group.model.js.map +0 -1
- package/models/user-guide.model.js +0 -4
- package/models/user-guide.model.js.map +0 -1
- package/models/user.model.d.ts +0 -84
- package/models/user.model.js +0 -4
- package/models/user.model.js.map +0 -1
- package/private/images/ResolveIO.png +0 -0
- package/public_api.js +0 -112
- package/public_api.js.map +0 -1
- package/publications/ai-terminal.d.ts +0 -1
- package/publications/ai-terminal.js +0 -122
- package/publications/ai-terminal.js.map +0 -1
- package/publications/app-settings.d.ts +0 -2
- package/publications/app-settings.js +0 -28
- package/publications/app-settings.js.map +0 -1
- package/publications/app-status.d.ts +0 -2
- package/publications/app-status.js +0 -16
- package/publications/app-status.js.map +0 -1
- package/publications/cron-jobs.d.ts +0 -2
- package/publications/cron-jobs.js +0 -88
- package/publications/cron-jobs.js.map +0 -1
- package/publications/customer-notifications.d.ts +0 -2
- package/publications/customer-notifications.js +0 -161
- package/publications/customer-notifications.js.map +0 -1
- package/publications/files.d.ts +0 -2
- package/publications/files.js +0 -36
- package/publications/files.js.map +0 -1
- package/publications/flags-update.d.ts +0 -2
- package/publications/flags-update.js +0 -22
- package/publications/flags-update.js.map +0 -1
- package/publications/flags.d.ts +0 -2
- package/publications/flags.js +0 -22
- package/publications/flags.js.map +0 -1
- package/publications/logs.d.ts +0 -2
- package/publications/logs.js +0 -164
- package/publications/logs.js.map +0 -1
- package/publications/notifications.d.ts +0 -2
- package/publications/notifications.js +0 -16
- package/publications/notifications.js.map +0 -1
- package/publications/report-builder-dashboard-builders.d.ts +0 -2
- package/publications/report-builder-dashboard-builders.js +0 -42
- package/publications/report-builder-dashboard-builders.js.map +0 -1
- package/publications/report-builder-libraries.d.ts +0 -2
- package/publications/report-builder-libraries.js +0 -90
- package/publications/report-builder-libraries.js.map +0 -1
- package/publications/report-builder-reports.d.ts +0 -2
- package/publications/report-builder-reports.js +0 -50
- package/publications/report-builder-reports.js.map +0 -1
- package/publications/super-admin.d.ts +0 -2
- package/publications/super-admin.js +0 -16
- package/publications/super-admin.js.map +0 -1
- package/publications/user-groups.d.ts +0 -1
- package/publications/user-groups.js +0 -16
- package/publications/user-groups.js.map +0 -1
- package/publications/user-guides.d.ts +0 -1
- package/publications/user-guides.js +0 -16
- package/publications/user-guides.js.map +0 -1
- package/resolveio-server-app.d.ts +0 -70
- package/resolveio-server-app.js +0 -801
- package/resolveio-server-app.js.map +0 -1
- package/server-app.d.ts +0 -228
- package/server-app.js +0 -3566
- package/server-app.js.map +0 -1
- package/services/codex-client.d.ts +0 -126
- package/services/codex-client.js +0 -1622
- package/services/codex-client.js.map +0 -1
- package/services/openai-client.d.ts +0 -46
- package/services/openai-client.js +0 -318
- package/services/openai-client.js.map +0 -1
- package/types/error-report.d.ts +0 -25
- package/types/error-report.js +0 -4
- package/types/error-report.js.map +0 -1
- package/types/slow-query-report.d.ts +0 -27
- package/types/slow-query-report.js +0 -6
- package/types/slow-query-report.js.map +0 -1
- package/util/ai-qa-policy.d.ts +0 -94
- package/util/ai-qa-policy.js +0 -534
- package/util/ai-qa-policy.js.map +0 -1
- package/util/common.d.ts +0 -31
- package/util/common.js +0 -683
- package/util/common.js.map +0 -1
- package/util/customer-portal-password.d.ts +0 -13
- package/util/customer-portal-password.js +0 -209
- package/util/customer-portal-password.js.map +0 -1
- package/util/error-reporter.d.ts +0 -52
- package/util/error-reporter.js +0 -326
- package/util/error-reporter.js.map +0 -1
- package/util/error-tracking.d.ts +0 -13
- package/util/error-tracking.js +0 -120
- package/util/error-tracking.js.map +0 -1
- package/util/report-builder-unwinds.d.ts +0 -15
- package/util/report-builder-unwinds.js +0 -156
- package/util/report-builder-unwinds.js.map +0 -1
- package/util/schema-report-builder.d.ts +0 -6
- package/util/schema-report-builder.js +0 -481
- package/util/schema-report-builder.js.map +0 -1
- package/util/slow-query-reporter.d.ts +0 -28
- package/util/slow-query-reporter.js +0 -226
- package/util/slow-query-reporter.js.map +0 -1
- package/util/subscription-dependency-context.d.ts +0 -34
- package/util/subscription-dependency-context.js +0 -1283
- package/util/subscription-dependency-context.js.map +0 -1
- package/util/tokenizer.d.ts +0 -5
- package/util/tokenizer.js +0 -41
- package/util/tokenizer.js.map +0 -1
- package/workers/codex-runner.worker.d.ts +0 -1
- package/workers/codex-runner.worker.js +0 -192
- package/workers/codex-runner.worker.js.map +0 -1
- /package/{private → src/private}/email-templates/enrollment.html +0 -0
- /package/{private → src/private}/email-templates/forgot-password.html +0 -0
- /package/{private → src/private}/email-templates/support-ticket-deleted.html +0 -0
- /package/{private → src/private}/email-templates/support-ticket-modified.html +0 -0
- /package/{private → src/private}/email-templates/support-ticket.html +0 -0
- /package/{public_api.d.ts → src/public_api.ts} +0 -0
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
import { recordAggregateDependencies, recordDependencyResult, withDependencyTracking } from '../src/util/subscription-dependency-context';
|
|
2
|
+
|
|
3
|
+
function assert(condition: boolean, message: string) {
|
|
4
|
+
if (!condition) {
|
|
5
|
+
throw new Error(message);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
async function testTracksIdsFromResults() {
|
|
10
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
11
|
+
recordDependencyResult('primary', [
|
|
12
|
+
{ _id: 'A' },
|
|
13
|
+
{ _id: 'B' },
|
|
14
|
+
{ _id: { toString: () => 'C' } }
|
|
15
|
+
]);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
const primary = snapshot.dependencies.get('primary');
|
|
19
|
+
|
|
20
|
+
assert(primary instanceof Set, 'Expected dependency set for primary collection');
|
|
21
|
+
assert(primary.size === 3, 'Expected three tracked ids for primary collection');
|
|
22
|
+
assert(primary.has('A') && primary.has('B') && primary.has('C'), 'Tracked ids missing expected values');
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
async function testFallsBackToWatchAllWithoutIds() {
|
|
26
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
27
|
+
recordDependencyResult('no-ids', [{ foo: 'bar' }]);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
assert(snapshot.watchAllCollections.has('no-ids'), 'Expected no-ids collection marked as watch-all');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
async function testCollectsLookupDependencies() {
|
|
34
|
+
const pipeline = [
|
|
35
|
+
{
|
|
36
|
+
$lookup: {
|
|
37
|
+
from: 'secondary',
|
|
38
|
+
localField: 'id_secondary',
|
|
39
|
+
foreignField: '_id',
|
|
40
|
+
as: 'secondaryDocs'
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
];
|
|
44
|
+
|
|
45
|
+
const result = [
|
|
46
|
+
{
|
|
47
|
+
_id: 'P1',
|
|
48
|
+
secondaryDocs: [
|
|
49
|
+
{ _id: 'S1' },
|
|
50
|
+
{ _id: { toHexString: () => 'S2' } }
|
|
51
|
+
]
|
|
52
|
+
}
|
|
53
|
+
];
|
|
54
|
+
|
|
55
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
56
|
+
recordAggregateDependencies('primary', pipeline, result);
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
const primary = snapshot.dependencies.get('primary');
|
|
60
|
+
const secondary = snapshot.dependencies.get('secondary');
|
|
61
|
+
|
|
62
|
+
assert(primary?.has('P1'), 'Expected primary dependency to include P1');
|
|
63
|
+
assert(secondary?.has('S1'), 'Expected secondary dependency to include S1');
|
|
64
|
+
assert(secondary?.has('S2'), 'Expected secondary dependency to include S2');
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
async function testLookupFilterStoredWhenNoMatches() {
|
|
68
|
+
const pipeline = [
|
|
69
|
+
{
|
|
70
|
+
$lookup: {
|
|
71
|
+
from: 'secondary',
|
|
72
|
+
localField: 'id_secondary',
|
|
73
|
+
foreignField: 'id_parent',
|
|
74
|
+
as: 'secondaryDocs'
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
];
|
|
78
|
+
|
|
79
|
+
const result = [
|
|
80
|
+
{
|
|
81
|
+
_id: 'P1',
|
|
82
|
+
id_secondary: ['X1', 'X2'],
|
|
83
|
+
secondaryDocs: []
|
|
84
|
+
}
|
|
85
|
+
];
|
|
86
|
+
|
|
87
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
88
|
+
recordAggregateDependencies('primary', pipeline, result);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
const filters = snapshot.filters.get('secondary');
|
|
92
|
+
|
|
93
|
+
assert(filters && filters.length === 1, 'Expected one filter stored for secondary collection');
|
|
94
|
+
assert(filters[0].id_parent && Array.isArray(filters[0].id_parent.$in), 'Expected filter to use $in on id_parent');
|
|
95
|
+
assert(filters[0].id_parent.$in.includes('X1'), 'Expected filter to include X1');
|
|
96
|
+
assert(filters[0].id_parent.$in.includes('X2'), 'Expected filter to include X2');
|
|
97
|
+
assert(!snapshot.watchAllCollections.has('secondary'), 'Expected secondary collection not marked as watch-all');
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
async function testMatchFilterCapturedForPrimary() {
|
|
101
|
+
const pipeline = [
|
|
102
|
+
{
|
|
103
|
+
$match: {
|
|
104
|
+
status: 'Active',
|
|
105
|
+
id_customer: { $in: ['C1', 'C2'] }
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
$lookup: {
|
|
110
|
+
from: 'secondary',
|
|
111
|
+
localField: 'id_secondary',
|
|
112
|
+
foreignField: '_id',
|
|
113
|
+
as: 'secondaryDocs'
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
];
|
|
117
|
+
|
|
118
|
+
const result = [
|
|
119
|
+
{
|
|
120
|
+
_id: 'P1',
|
|
121
|
+
status: 'Active',
|
|
122
|
+
id_customer: 'C1',
|
|
123
|
+
secondaryDocs: []
|
|
124
|
+
}
|
|
125
|
+
];
|
|
126
|
+
|
|
127
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
128
|
+
recordAggregateDependencies('primary', pipeline, result);
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
const filters = snapshot.filters.get('primary');
|
|
132
|
+
|
|
133
|
+
assert(filters && filters.length === 1, 'Expected one filter stored for primary collection');
|
|
134
|
+
const storedFilter = filters[0];
|
|
135
|
+
assert(storedFilter.status === 'Active', 'Expected status to be Active in stored filter');
|
|
136
|
+
assert(storedFilter.id_customer && Array.isArray(storedFilter.id_customer.$in), 'Expected id_customer filter to use $in');
|
|
137
|
+
assert(storedFilter.id_customer.$in.includes('C1'), 'Expected filter to include C1');
|
|
138
|
+
assert(storedFilter.id_customer.$in.includes('C2'), 'Expected filter to include C2');
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
async function testMatchFilterIgnoresLookupAliases() {
|
|
142
|
+
const pipeline = [
|
|
143
|
+
{
|
|
144
|
+
$match: {
|
|
145
|
+
type: 'Truck Treat'
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
{
|
|
149
|
+
$lookup: {
|
|
150
|
+
from: 'bols',
|
|
151
|
+
localField: 'id_bol',
|
|
152
|
+
foreignField: '_id',
|
|
153
|
+
as: 'bol'
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
{
|
|
157
|
+
$match: {
|
|
158
|
+
'bol.status': 'Delivered',
|
|
159
|
+
approved: true
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
];
|
|
163
|
+
|
|
164
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
165
|
+
recordAggregateDependencies('production-deliveries', pipeline, []);
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
const filters = snapshot.filters.get('production-deliveries');
|
|
169
|
+
|
|
170
|
+
assert(filters && filters.length === 1, 'Expected sanitized filter stored for production-deliveries');
|
|
171
|
+
const storedFilter = filters[0];
|
|
172
|
+
|
|
173
|
+
const serialized = JSON.stringify(storedFilter);
|
|
174
|
+
assert(!serialized.includes('bol.status'), 'Expected lookup alias fields stripped from stored filter');
|
|
175
|
+
assert(serialized.includes('type'), 'Expected base collection field retained');
|
|
176
|
+
assert(serialized.includes('approved'), 'Expected base collection field retained');
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
async function testFindQueryMetadataCaptured() {
|
|
180
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
181
|
+
recordDependencyResult('primary', [{ _id: 'P1' }], {
|
|
182
|
+
filter: { status: 'Active' },
|
|
183
|
+
meta: {
|
|
184
|
+
limit: 25,
|
|
185
|
+
skip: 0,
|
|
186
|
+
sort: { createdAt: -1 }
|
|
187
|
+
}
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
const meta = snapshot.queryMetadata.get('primary');
|
|
192
|
+
|
|
193
|
+
assert(meta && meta.length === 1, 'Expected query metadata stored for primary collection');
|
|
194
|
+
assert(meta[0].limit === 25, 'Expected limit metadata to equal 25');
|
|
195
|
+
assert(meta[0].sort && meta[0].sort.createdAt === -1, 'Expected sort metadata captured');
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
async function testAggregateMetadataCaptured() {
|
|
199
|
+
const pipeline = [
|
|
200
|
+
{$match: { status: 'Active' }},
|
|
201
|
+
{$sort: { createdAt: -1 }},
|
|
202
|
+
{$skip: 10},
|
|
203
|
+
{$limit: 5}
|
|
204
|
+
];
|
|
205
|
+
|
|
206
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
207
|
+
recordAggregateDependencies('primary', pipeline, []);
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
const meta = snapshot.queryMetadata.get('primary');
|
|
211
|
+
|
|
212
|
+
assert(meta && meta.length === 1, 'Expected aggregate metadata stored for primary collection');
|
|
213
|
+
assert(meta[0].limit === 5, 'Expected aggregate limit metadata to equal 5');
|
|
214
|
+
assert(meta[0].skip === 10, 'Expected aggregate skip metadata to equal 10');
|
|
215
|
+
assert(meta[0].sort && meta[0].sort.createdAt === -1, 'Expected aggregate sort metadata captured');
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
async function testLookupPipelineFiltersCaptured() {
|
|
219
|
+
const pipeline = [
|
|
220
|
+
{
|
|
221
|
+
$lookup: {
|
|
222
|
+
from: 'orders',
|
|
223
|
+
let: { customerId: '$customer.id' },
|
|
224
|
+
pipeline: [
|
|
225
|
+
{
|
|
226
|
+
$match: {
|
|
227
|
+
$expr: {
|
|
228
|
+
$eq: ['$id_customer', '$$customerId']
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
],
|
|
233
|
+
as: 'orders'
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
];
|
|
237
|
+
|
|
238
|
+
const result = [
|
|
239
|
+
{
|
|
240
|
+
_id: 'cust-1',
|
|
241
|
+
customer: {
|
|
242
|
+
id: 'CUST-A'
|
|
243
|
+
},
|
|
244
|
+
orders: []
|
|
245
|
+
}
|
|
246
|
+
];
|
|
247
|
+
|
|
248
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
249
|
+
recordAggregateDependencies('customers', pipeline, result);
|
|
250
|
+
});
|
|
251
|
+
|
|
252
|
+
const filters = snapshot.filters.get('orders');
|
|
253
|
+
|
|
254
|
+
assert(filters && filters.length === 1, 'Expected one filter stored for orders lookup pipeline');
|
|
255
|
+
assert(filters[0].$expr && filters[0].$expr.$eq, 'Expected pipeline filter to contain $expr equality');
|
|
256
|
+
assert(filters[0].$expr.$eq[1] === 'CUST-A', 'Expected lookup pipeline filter to include substituted customer id');
|
|
257
|
+
assert(!snapshot.watchAllCollections.has('orders'), 'Expected orders collection not marked as watch-all for pipeline lookup');
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
async function testGroupPipelineMarksWatchAll() {
|
|
261
|
+
const pipeline = [
|
|
262
|
+
{$match: {status: 'Active'}},
|
|
263
|
+
{
|
|
264
|
+
$group: {
|
|
265
|
+
_id: '$type',
|
|
266
|
+
count: {$sum: 1}
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
];
|
|
270
|
+
|
|
271
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
272
|
+
recordAggregateDependencies('orders', pipeline, [{_id: 'Truck', count: 3}]);
|
|
273
|
+
});
|
|
274
|
+
|
|
275
|
+
assert(snapshot.watchAllCollections.has('orders'), 'Expected grouped aggregate to mark orders as watch-all');
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
async function testLookupPipelineWithoutResolvableFiltersMarksWatchAll() {
|
|
279
|
+
const pipeline = [
|
|
280
|
+
{
|
|
281
|
+
$lookup: {
|
|
282
|
+
from: 'orders',
|
|
283
|
+
pipeline: [
|
|
284
|
+
{$sort: {createdAt: -1}},
|
|
285
|
+
{$limit: 5}
|
|
286
|
+
],
|
|
287
|
+
as: 'orders'
|
|
288
|
+
}
|
|
289
|
+
},
|
|
290
|
+
{
|
|
291
|
+
$project: {
|
|
292
|
+
orders: 0
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
];
|
|
296
|
+
|
|
297
|
+
const { snapshot } = await withDependencyTracking(async () => {
|
|
298
|
+
recordAggregateDependencies('customers', pipeline, [{_id: 'cust-1'}]);
|
|
299
|
+
});
|
|
300
|
+
|
|
301
|
+
assert(snapshot.watchAllCollections.has('orders'), 'Expected lookup collection orders marked as watch-all when alias results are unavailable');
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
async function run() {
|
|
305
|
+
await testTracksIdsFromResults();
|
|
306
|
+
await testFallsBackToWatchAllWithoutIds();
|
|
307
|
+
await testCollectsLookupDependencies();
|
|
308
|
+
await testLookupFilterStoredWhenNoMatches();
|
|
309
|
+
await testMatchFilterCapturedForPrimary();
|
|
310
|
+
await testMatchFilterIgnoresLookupAliases();
|
|
311
|
+
await testFindQueryMetadataCaptured();
|
|
312
|
+
await testAggregateMetadataCaptured();
|
|
313
|
+
await testLookupPipelineFiltersCaptured();
|
|
314
|
+
await testGroupPipelineMarksWatchAll();
|
|
315
|
+
await testLookupPipelineWithoutResolvableFiltersMarksWatchAll();
|
|
316
|
+
|
|
317
|
+
console.log('subscription dependency tests passed');
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
run().catch(err => {
|
|
321
|
+
console.error('subscription dependency tests failed');
|
|
322
|
+
console.error(err);
|
|
323
|
+
process.exit(1);
|
|
324
|
+
});
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { SubscriptionManager } from '../src/managers/subscription.manager';
|
|
2
|
+
import { ActiveSubscriptionModel } from '../src/models/subscription.model';
|
|
3
|
+
|
|
4
|
+
function assert(condition: boolean, message: string) {
|
|
5
|
+
if (!condition) {
|
|
6
|
+
throw new Error(message);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
function createBaseSubscription(): ActiveSubscriptionModel {
|
|
11
|
+
return {
|
|
12
|
+
publication: 'productionlocationDetailsWithId',
|
|
13
|
+
subscriptionKey: '[]',
|
|
14
|
+
subscriptionData: [],
|
|
15
|
+
collections: ['production-locations'],
|
|
16
|
+
clients: [],
|
|
17
|
+
cacheId: 0,
|
|
18
|
+
running: false,
|
|
19
|
+
runAgain: false,
|
|
20
|
+
collectionDependencies: new Map(),
|
|
21
|
+
collectionFilters: new Map(),
|
|
22
|
+
watchAllCollections: new Set(),
|
|
23
|
+
collectionQueryMeta: new Map()
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
async function testTracksRuntimeDependencies() {
|
|
28
|
+
const manager = new SubscriptionManager() as any;
|
|
29
|
+
const sub = createBaseSubscription();
|
|
30
|
+
manager.ensureDependencyContainers(sub);
|
|
31
|
+
|
|
32
|
+
sub.collectionDependencies.set('truck-treating-deliveries', new Set(['TT1']));
|
|
33
|
+
|
|
34
|
+
assert(
|
|
35
|
+
manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
|
|
36
|
+
'Expected dynamic dependency ids to mark collection as tracked'
|
|
37
|
+
);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async function testTracksFiltersAndWatchAll() {
|
|
41
|
+
const manager = new SubscriptionManager() as any;
|
|
42
|
+
const sub = createBaseSubscription();
|
|
43
|
+
manager.ensureDependencyContainers(sub);
|
|
44
|
+
|
|
45
|
+
sub.collectionFilters.set('truck-treating-deliveries', [{status: 'Scheduled'}]);
|
|
46
|
+
|
|
47
|
+
assert(
|
|
48
|
+
manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
|
|
49
|
+
'Expected dependency filters to mark collection as tracked'
|
|
50
|
+
);
|
|
51
|
+
|
|
52
|
+
sub.collectionFilters.clear();
|
|
53
|
+
sub.watchAllCollections.add('truck-treating-deliveries');
|
|
54
|
+
|
|
55
|
+
assert(
|
|
56
|
+
manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
|
|
57
|
+
'Expected watch-all collections to be considered tracked'
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
async function testNonTrackedCollection() {
|
|
62
|
+
const manager = new SubscriptionManager() as any;
|
|
63
|
+
const sub = createBaseSubscription();
|
|
64
|
+
manager.ensureDependencyContainers(sub);
|
|
65
|
+
|
|
66
|
+
assert(
|
|
67
|
+
!manager.subscriptionReferencesCollection(sub, 'truck-treating-deliveries'),
|
|
68
|
+
'Expected unrelated collections to remain untracked'
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
async function run() {
|
|
73
|
+
await testTracksRuntimeDependencies();
|
|
74
|
+
await testTracksFiltersAndWatchAll();
|
|
75
|
+
await testNonTrackedCollection();
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
run()
|
|
79
|
+
.then(() => {
|
|
80
|
+
console.log('subscription-manager-collection-tracking tests completed');
|
|
81
|
+
process.exit(0);
|
|
82
|
+
})
|
|
83
|
+
.catch(error => {
|
|
84
|
+
console.error(error);
|
|
85
|
+
process.exit(1);
|
|
86
|
+
});
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { SubscriptionManager } from '../src/managers/subscription.manager';
|
|
2
|
+
import { ActiveSubscriptionModel } from '../src/models/subscription.model';
|
|
3
|
+
|
|
4
|
+
function assert(condition: boolean, message: string) {
|
|
5
|
+
if (!condition) {
|
|
6
|
+
throw new Error(message);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
function createBaseSubscription(): ActiveSubscriptionModel {
|
|
11
|
+
return {
|
|
12
|
+
publication: 'testPublication',
|
|
13
|
+
subscriptionKey: '[]',
|
|
14
|
+
subscriptionData: [],
|
|
15
|
+
collections: ['orders'],
|
|
16
|
+
clients: [],
|
|
17
|
+
cacheId: 0,
|
|
18
|
+
running: false,
|
|
19
|
+
runAgain: false,
|
|
20
|
+
collectionDependencies: new Map(),
|
|
21
|
+
collectionFilters: new Map(),
|
|
22
|
+
watchAllCollections: new Set(),
|
|
23
|
+
collectionQueryMeta: new Map()
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
async function testFilterOnlyDeleteInvalidates() {
|
|
28
|
+
const manager = new SubscriptionManager() as any;
|
|
29
|
+
const sub = createBaseSubscription();
|
|
30
|
+
manager.ensureDependencyContainers(sub);
|
|
31
|
+
sub.collectionFilters.set('orders', [{status: 'Active'}]);
|
|
32
|
+
|
|
33
|
+
const shouldInvalidate = await manager.shouldInvalidateSubscription(sub, 'orders', 'delete', 'ORD-1');
|
|
34
|
+
assert(shouldInvalidate, 'Expected filter-only delete to invalidate subscription');
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
async function testFilterOnlyUpdateInvalidates() {
|
|
38
|
+
const manager = new SubscriptionManager() as any;
|
|
39
|
+
const sub = createBaseSubscription();
|
|
40
|
+
manager.ensureDependencyContainers(sub);
|
|
41
|
+
sub.collectionFilters.set('orders', [{status: 'Active'}]);
|
|
42
|
+
|
|
43
|
+
const shouldInvalidate = await manager.shouldInvalidateSubscription(
|
|
44
|
+
sub,
|
|
45
|
+
'orders',
|
|
46
|
+
'update',
|
|
47
|
+
'ORD-1',
|
|
48
|
+
{_id: 'ORD-1', status: 'Archived'}
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
assert(shouldInvalidate, 'Expected filter-only update to invalidate subscription when tracked ids are unavailable');
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
async function testTrackedDeleteUnknownIdSkips() {
|
|
55
|
+
const manager = new SubscriptionManager() as any;
|
|
56
|
+
const sub = createBaseSubscription();
|
|
57
|
+
manager.ensureDependencyContainers(sub);
|
|
58
|
+
sub.collectionDependencies.set('orders', new Set(['ORD-1']));
|
|
59
|
+
|
|
60
|
+
const shouldInvalidate = await manager.shouldInvalidateSubscription(sub, 'orders', 'delete', 'ORD-2');
|
|
61
|
+
assert(!shouldInvalidate, 'Expected delete on unknown tracked id to skip invalidation');
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
async function testTrackedDeleteKnownIdInvalidates() {
|
|
65
|
+
const manager = new SubscriptionManager() as any;
|
|
66
|
+
const sub = createBaseSubscription();
|
|
67
|
+
manager.ensureDependencyContainers(sub);
|
|
68
|
+
sub.collectionDependencies.set('orders', new Set(['ORD-1']));
|
|
69
|
+
|
|
70
|
+
const shouldInvalidate = await manager.shouldInvalidateSubscription(sub, 'orders', 'delete', 'ORD-1');
|
|
71
|
+
assert(shouldInvalidate, 'Expected delete on tracked id to invalidate subscription');
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
async function run() {
|
|
75
|
+
await testFilterOnlyDeleteInvalidates();
|
|
76
|
+
await testFilterOnlyUpdateInvalidates();
|
|
77
|
+
await testTrackedDeleteUnknownIdSkips();
|
|
78
|
+
await testTrackedDeleteKnownIdInvalidates();
|
|
79
|
+
console.log('subscription-manager-invalidation tests completed');
|
|
80
|
+
process.exit(0);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
run().catch(error => {
|
|
84
|
+
console.error(error);
|
|
85
|
+
process.exit(1);
|
|
86
|
+
});
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compileOnSave": false,
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"outDir": "./dist/out-tsc",
|
|
5
|
+
"sourceMap": true,
|
|
6
|
+
"declaration": true,
|
|
7
|
+
"declarationMap": true,
|
|
8
|
+
"inlineSources": true,
|
|
9
|
+
"baseUrl": ".",
|
|
10
|
+
"module": "commonjs",
|
|
11
|
+
"moduleResolution": "node",
|
|
12
|
+
"emitDecoratorMetadata": true,
|
|
13
|
+
"experimentalDecorators": true,
|
|
14
|
+
"target": "es5",
|
|
15
|
+
"skipLibCheck": true,
|
|
16
|
+
"stripInternal": true,
|
|
17
|
+
"noImplicitAny": false,
|
|
18
|
+
"downlevelIteration": true,
|
|
19
|
+
"typeRoots": [
|
|
20
|
+
"node_modules/@types"
|
|
21
|
+
],
|
|
22
|
+
"lib": [
|
|
23
|
+
"es2017",
|
|
24
|
+
"dom"
|
|
25
|
+
],
|
|
26
|
+
"noImplicitReturns": true
|
|
27
|
+
},
|
|
28
|
+
"include": [
|
|
29
|
+
"./**/*.ts"
|
|
30
|
+
],
|
|
31
|
+
"exclude": [
|
|
32
|
+
"node_modules"
|
|
33
|
+
]
|
|
34
|
+
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
type AiAssistantCoreTermHint = {
|
|
2
|
-
terms: string[];
|
|
3
|
-
collections: string[];
|
|
4
|
-
};
|
|
5
|
-
export declare const AI_ASSISTANT_CORE_HEURISTICS: Readonly<{
|
|
6
|
-
version: 3;
|
|
7
|
-
collection_aliases: Record<string, string>;
|
|
8
|
-
collection_alias_options: Record<string, string[]>;
|
|
9
|
-
collection_term_hints: AiAssistantCoreTermHint[];
|
|
10
|
-
}>;
|
|
11
|
-
export {};
|