@archlast/server 0.1.8 → 0.1.9
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/README.md +104 -100
- package/dist/admin/auth.d.ts +24 -5
- package/dist/admin/auth.js +49 -25
- package/dist/admin/schema.d.ts +122 -32
- package/dist/admin/schema.js +131 -95
- package/dist/admin/seed.d.ts +1 -1
- package/dist/admin/seed.js +79 -47
- package/dist/auth/api-key-resolver.d.ts +1 -1
- package/dist/auth/api-key-resolver.js +7 -3
- package/dist/auth/archlast-auth-adapter.d.ts +2 -5
- package/dist/auth/archlast-auth-adapter.js +1 -1
- package/dist/auth/better-auth-adapter.d.ts.map +1 -1
- package/dist/auth/better-auth-adapter.js +41 -26
- package/dist/auth/better-auth-adapter.js.map +1 -1
- package/dist/auth/better-auth-admin.d.ts.map +1 -1
- package/dist/auth/better-auth-admin.js +1 -1
- package/dist/auth/better-auth-admin.js.map +1 -1
- package/dist/auth/better-auth-api-key-resolver.js +1 -1
- package/dist/auth/better-auth-api-key-resolver.js.map +1 -1
- package/dist/auth/better-auth-instance.d.ts +249 -301
- package/dist/auth/better-auth-instance.d.ts.map +1 -1
- package/dist/auth/better-auth-instance.js +11 -0
- package/dist/auth/better-auth-instance.js.map +1 -1
- package/dist/auth/better-auth-seed.d.ts +5 -2
- package/dist/auth/better-auth-seed.js +31 -22
- package/dist/auth/better-auth-session-adapter.d.ts.map +1 -1
- package/dist/auth/better-auth-session-adapter.js +14 -10
- package/dist/auth/better-auth-session-adapter.js.map +1 -1
- package/dist/auth/errors.d.ts.map +1 -1
- package/dist/auth/errors.js +11 -11
- package/dist/auth/errors.js.map +1 -1
- package/dist/auth/oauth-proxy.d.ts +5 -2
- package/dist/auth/oauth-proxy.js +23 -27
- package/dist/auth/resolver.d.ts.map +1 -1
- package/dist/auth/resolver.js.map +1 -1
- package/dist/auth/role-helpers.d.ts +1 -1
- package/dist/auth/role-helpers.d.ts.map +1 -1
- package/dist/auth/role-helpers.js.map +1 -1
- package/dist/auth/session-manager.d.ts +2 -5
- package/dist/auth/session-manager.js +16 -6
- package/dist/auth/system/better-auth-schema.d.ts.map +1 -1
- package/dist/auth/system/better-auth-schema.js +6 -23
- package/dist/auth/system/better-auth-schema.js.map +1 -1
- package/dist/cache/circuit-breaker.d.ts +81 -0
- package/dist/cache/circuit-breaker.d.ts.map +1 -0
- package/dist/cache/circuit-breaker.js +170 -0
- package/dist/cache/circuit-breaker.js.map +1 -0
- package/dist/cache/client.d.ts +6 -3
- package/dist/cache/client.d.ts.map +1 -1
- package/dist/cache/client.js +12 -53
- package/dist/cache/client.js.map +1 -1
- package/dist/cache/index.d.ts +2 -0
- package/dist/cache/index.d.ts.map +1 -1
- package/dist/cache/index.js +5 -1
- package/dist/cache/index.js.map +1 -1
- package/dist/cache/invalidation-queue.d.ts +63 -0
- package/dist/cache/invalidation-queue.d.ts.map +1 -0
- package/dist/cache/invalidation-queue.js +196 -0
- package/dist/cache/invalidation-queue.js.map +1 -0
- package/dist/cache/layers.d.ts +14 -4
- package/dist/cache/layers.d.ts.map +1 -1
- package/dist/cache/layers.js +66 -72
- package/dist/cache/layers.js.map +1 -1
- package/dist/cache/manager.d.ts.map +1 -1
- package/dist/cache/manager.js +6 -41
- package/dist/cache/manager.js.map +1 -1
- package/dist/cache/protocol.d.ts +4 -39
- package/dist/cache/protocol.d.ts.map +1 -1
- package/dist/cache/protocol.js.map +1 -1
- package/dist/cache/redis-adapter.d.ts +103 -0
- package/dist/cache/redis-adapter.d.ts.map +1 -0
- package/dist/cache/redis-adapter.js +424 -0
- package/dist/cache/redis-adapter.js.map +1 -0
- package/dist/cache/run-sidecar.js +10 -1
- package/dist/cache/run-sidecar.js.map +1 -1
- package/dist/cache/sidecar-server.d.ts +51 -1
- package/dist/cache/sidecar-server.d.ts.map +1 -1
- package/dist/cache/sidecar-server.js +368 -22
- package/dist/cache/sidecar-server.js.map +1 -1
- package/dist/cache/store.d.ts +43 -0
- package/dist/cache/store.d.ts.map +1 -1
- package/dist/cache/store.js +69 -76
- package/dist/cache/store.js.map +1 -1
- package/dist/cache/strategies.d.ts +2 -9
- package/dist/cache/strategies.d.ts.map +1 -1
- package/dist/cache/types.d.ts +130 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +60 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/config/bullmq.d.ts +16 -0
- package/dist/config/bullmq.d.ts.map +1 -0
- package/dist/config/bullmq.js +103 -0
- package/dist/config/bullmq.js.map +1 -0
- package/dist/config/index.d.ts +1 -0
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +1 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/schema.d.ts +80 -6
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +71 -6
- package/dist/config/schema.js.map +1 -1
- package/dist/config/service.d.ts +54 -4
- package/dist/config/service.d.ts.map +1 -1
- package/dist/config/service.js +56 -2
- package/dist/config/service.js.map +1 -1
- package/dist/controllers/admin/admin-tokens.controller.d.ts +131 -115
- package/dist/controllers/admin/admin-tokens.controller.js +117 -98
- package/dist/controllers/admin/api-keys.controller.d.ts +1 -1
- package/dist/controllers/admin/api-keys.controller.d.ts.map +1 -1
- package/dist/controllers/admin/api-keys.controller.js.map +1 -1
- package/dist/controllers/admin/app-users.controller.d.ts +274 -243
- package/dist/controllers/admin/app-users.controller.js +301 -257
- package/dist/controllers/admin/auth.controller.d.ts +260 -236
- package/dist/controllers/admin/auth.controller.js +197 -174
- package/dist/controllers/admin/backup.controller.d.ts.map +1 -1
- package/dist/controllers/admin/backup.controller.js.map +1 -1
- package/dist/controllers/admin/settings.controller.d.ts +1 -1
- package/dist/controllers/admin/storage-stats.controller.d.ts +63 -0
- package/dist/controllers/admin/storage-stats.controller.d.ts.map +1 -0
- package/dist/controllers/admin/storage-stats.controller.js +33 -0
- package/dist/controllers/admin/storage-stats.controller.js.map +1 -0
- package/dist/controllers/admin/tenants.controller.d.ts.map +1 -1
- package/dist/controllers/admin/tenants.controller.js.map +1 -1
- package/dist/controllers/admin/users.controller.d.ts +1 -1
- package/dist/controllers/admin/users.controller.d.ts.map +1 -1
- package/dist/controllers/admin/users.controller.js.map +1 -1
- package/dist/controllers/auth.controller.d.ts +289 -271
- package/dist/controllers/auth.controller.js +275 -226
- package/dist/controllers/crud-generator.controller.d.ts.map +1 -1
- package/dist/controllers/crud-generator.controller.js +127 -125
- package/dist/controllers/crud-generator.controller.js.map +1 -1
- package/dist/controllers/index.d.ts +1 -1
- package/dist/controllers/index.d.ts.map +1 -1
- package/dist/controllers/index.js.map +1 -1
- package/dist/controllers/introspection.controller.d.ts +642 -0
- package/dist/controllers/introspection.controller.d.ts.map +1 -1
- package/dist/controllers/introspection.controller.js +611 -0
- package/dist/controllers/introspection.controller.js.map +1 -1
- package/dist/controllers/invite.controller.d.ts +190 -170
- package/dist/controllers/invite.controller.js +183 -164
- package/dist/controllers/mfa.controller.d.ts +205 -183
- package/dist/controllers/mfa.controller.js +131 -111
- package/dist/controllers/otp.controller.d.ts +194 -171
- package/dist/controllers/otp.controller.js +192 -175
- package/dist/controllers/storage.controller.d.ts.map +1 -1
- package/dist/controllers/storage.controller.js.map +1 -1
- package/dist/controllers/system.controller.d.ts +5 -3
- package/dist/controllers/system.controller.d.ts.map +1 -1
- package/dist/controllers/system.controller.js +4 -2
- package/dist/controllers/system.controller.js.map +1 -1
- package/dist/controllers/tenant.controller.d.ts +258 -227
- package/dist/controllers/tenant.controller.js +224 -200
- package/dist/db/cachedclient.d.ts +6 -11
- package/dist/db/cachedclient.d.ts.map +1 -1
- package/dist/db/cachedclient.js +79 -43
- package/dist/db/cachedclient.js.map +1 -1
- package/dist/db/distributed-client.d.ts +79 -24
- package/dist/db/distributed-client.js +23 -24
- package/dist/db/factory.d.ts +3 -8
- package/dist/db/factory.d.ts.map +1 -1
- package/dist/db/factory.js +3 -22
- package/dist/db/factory.js.map +1 -1
- package/dist/db/socket-client.d.ts +7 -0
- package/dist/db/socket-client.d.ts.map +1 -1
- package/dist/db/socket-client.js +140 -11
- package/dist/db/socket-client.js.map +1 -1
- package/dist/deployment/handler.d.ts +10 -2
- package/dist/deployment/handler.d.ts.map +1 -1
- package/dist/deployment/handler.js +70 -15
- package/dist/deployment/handler.js.map +1 -1
- package/dist/deployment/persistence.d.ts.map +1 -1
- package/dist/deployment/persistence.js +6 -1
- package/dist/deployment/persistence.js.map +1 -1
- package/dist/docker/compose.d.ts.map +1 -1
- package/dist/docker/compose.js +76 -0
- package/dist/docker/compose.js.map +1 -1
- package/dist/engine/runner.d.ts.map +1 -1
- package/dist/engine/runner.js +0 -43
- package/dist/engine/runner.js.map +1 -1
- package/dist/functions/built-in/auth-apikey.d.ts.map +1 -1
- package/dist/functions/built-in/auth-apikey.js.map +1 -1
- package/dist/functions/built-in/system-cache.d.ts.map +1 -1
- package/dist/functions/built-in/system-cache.js +6 -31
- package/dist/functions/built-in/system-cache.js.map +1 -1
- package/dist/functions/built-in/system-data.d.ts.map +1 -1
- package/dist/functions/built-in/system-data.js +4 -2
- package/dist/functions/built-in/system-data.js.map +1 -1
- package/dist/functions/definition.d.ts.map +1 -1
- package/dist/functions/definition.js +6 -2
- package/dist/functions/definition.js.map +1 -1
- package/dist/http/routes/metrics.d.ts +42 -0
- package/dist/http/routes/metrics.d.ts.map +1 -0
- package/dist/http/routes/metrics.js +29 -0
- package/dist/http/routes/metrics.js.map +1 -0
- package/dist/http/server.d.ts +1 -0
- package/dist/http/server.d.ts.map +1 -1
- package/dist/http/server.js +41 -3
- package/dist/http/server.js.map +1 -1
- package/dist/ipc/socket-bridge.d.ts +1 -0
- package/dist/ipc/socket-bridge.d.ts.map +1 -1
- package/dist/ipc/socket-bridge.js +5 -1
- package/dist/ipc/socket-bridge.js.map +1 -1
- package/dist/jobs/bullmq-adapter.d.ts +154 -0
- package/dist/jobs/bullmq-adapter.d.ts.map +1 -0
- package/dist/jobs/bullmq-adapter.js +688 -0
- package/dist/jobs/bullmq-adapter.js.map +1 -0
- package/dist/jobs/bullmq-circuit-breaker.d.ts +133 -0
- package/dist/jobs/bullmq-circuit-breaker.d.ts.map +1 -0
- package/dist/jobs/bullmq-circuit-breaker.js +323 -0
- package/dist/jobs/bullmq-circuit-breaker.js.map +1 -0
- package/dist/jobs/bullmq-dlq-manager.d.ts +155 -0
- package/dist/jobs/bullmq-dlq-manager.d.ts.map +1 -0
- package/dist/jobs/bullmq-dlq-manager.js +325 -0
- package/dist/jobs/bullmq-dlq-manager.js.map +1 -0
- package/dist/jobs/bullmq-metrics.d.ts +104 -0
- package/dist/jobs/bullmq-metrics.d.ts.map +1 -0
- package/dist/jobs/bullmq-metrics.js +323 -0
- package/dist/jobs/bullmq-metrics.js.map +1 -0
- package/dist/jobs/bullmq-priority-service.d.ts +173 -0
- package/dist/jobs/bullmq-priority-service.d.ts.map +1 -0
- package/dist/jobs/bullmq-priority-service.js +390 -0
- package/dist/jobs/bullmq-priority-service.js.map +1 -0
- package/dist/jobs/bullmq-scheduler.d.ts +111 -0
- package/dist/jobs/bullmq-scheduler.d.ts.map +1 -0
- package/dist/jobs/bullmq-scheduler.js +300 -0
- package/dist/jobs/bullmq-scheduler.js.map +1 -0
- package/dist/jobs/bullmq-worker.d.ts +155 -0
- package/dist/jobs/bullmq-worker.d.ts.map +1 -0
- package/dist/jobs/bullmq-worker.js +651 -0
- package/dist/jobs/bullmq-worker.js.map +1 -0
- package/dist/jobs/circuit-breaker.d.ts +120 -0
- package/dist/jobs/circuit-breaker.d.ts.map +1 -0
- package/dist/jobs/circuit-breaker.js +262 -0
- package/dist/jobs/circuit-breaker.js.map +1 -0
- package/dist/jobs/index.d.ts +1 -1
- package/dist/jobs/index.d.ts.map +1 -1
- package/dist/jobs/index.js.map +1 -1
- package/dist/jobs/queue.d.ts +120 -1
- package/dist/jobs/queue.d.ts.map +1 -1
- package/dist/jobs/queue.js +487 -9
- package/dist/jobs/queue.js.map +1 -1
- package/dist/jobs/redis-connection.d.ts +50 -0
- package/dist/jobs/redis-connection.d.ts.map +1 -0
- package/dist/jobs/redis-connection.js +123 -0
- package/dist/jobs/redis-connection.js.map +1 -0
- package/dist/jobs/run-scheduler.js +163 -10
- package/dist/jobs/run-scheduler.js.map +1 -1
- package/dist/jobs/run-worker.js +101 -9
- package/dist/jobs/run-worker.js.map +1 -1
- package/dist/jobs/worker-thread.d.ts +6 -0
- package/dist/jobs/worker-thread.d.ts.map +1 -1
- package/dist/jobs/worker-thread.js +37 -8
- package/dist/jobs/worker-thread.js.map +1 -1
- package/dist/jobs/worker.d.ts +33 -0
- package/dist/jobs/worker.d.ts.map +1 -1
- package/dist/jobs/worker.js +358 -115
- package/dist/jobs/worker.js.map +1 -1
- package/dist/linq/async-enumerable.d.ts.map +1 -1
- package/dist/linq/async-enumerable.js.map +1 -1
- package/dist/linq/enumerable.d.ts.map +1 -1
- package/dist/linq/enumerable.js +10 -10
- package/dist/linq/enumerable.js.map +1 -1
- package/dist/metrics/collector.d.ts +26 -0
- package/dist/metrics/collector.d.ts.map +1 -0
- package/dist/metrics/collector.js +103 -0
- package/dist/metrics/collector.js.map +1 -0
- package/dist/polling/updates.controller.d.ts +57 -0
- package/dist/polling/updates.controller.d.ts.map +1 -0
- package/dist/polling/updates.controller.js +70 -0
- package/dist/polling/updates.controller.js.map +1 -0
- package/dist/repository/db-set.d.ts.map +1 -1
- package/dist/repository/db-set.js +12 -8
- package/dist/repository/db-set.js.map +1 -1
- package/dist/repository/ef-core.d.ts.map +1 -1
- package/dist/repository/ef-core.js +6 -6
- package/dist/repository/ef-core.js.map +1 -1
- package/dist/repository/factory.d.ts +1 -1
- package/dist/repository/factory.d.ts.map +1 -1
- package/dist/repository/factory.js.map +1 -1
- package/dist/repository/interfaces.d.ts.map +1 -1
- package/dist/repository/interfaces.js.map +1 -1
- package/dist/repository/queryable.d.ts.map +1 -1
- package/dist/repository/queryable.js.map +1 -1
- package/dist/rpc/adapter.d.ts.map +1 -1
- package/dist/rpc/adapter.js.map +1 -1
- package/dist/rpc/router.d.ts +2 -2
- package/dist/rpc/router.d.ts.map +1 -1
- package/dist/rpc/router.js +1 -1
- package/dist/rpc/router.js.map +1 -1
- package/dist/schema/relationship-types.d.ts +7 -2
- package/dist/schema/relationship-types.js +1 -1
- package/dist/schema/types.d.ts.map +1 -1
- package/dist/services/admin/app-users.service.d.ts +1 -1
- package/dist/services/admin/app-users.service.js +31 -38
- package/dist/services/admin/auth.service.d.ts +1 -1
- package/dist/services/admin/auth.service.js +11 -5
- package/dist/services/admin/backup/BackupOrchestrator.d.ts.map +1 -1
- package/dist/services/admin/backup/BackupOrchestrator.js +4 -7
- package/dist/services/admin/backup/BackupOrchestrator.js.map +1 -1
- package/dist/services/admin/backup/SqliteGenerator.js +8 -8
- package/dist/services/admin/backup/StorageStreamer.d.ts +3 -3
- package/dist/services/admin/backup/StorageStreamer.d.ts.map +1 -1
- package/dist/services/admin/backup/StorageStreamer.js +16 -55
- package/dist/services/admin/backup/StorageStreamer.js.map +1 -1
- package/dist/services/admin/backup/ZipComposer.d.ts +2 -0
- package/dist/services/admin/backup/ZipComposer.d.ts.map +1 -1
- package/dist/services/admin/backup/ZipComposer.js +23 -0
- package/dist/services/admin/backup/ZipComposer.js.map +1 -1
- package/dist/services/admin/backup.service.d.ts.map +1 -1
- package/dist/services/admin/backup.service.js.map +1 -1
- package/dist/services/admin/data.service.d.ts.map +1 -1
- package/dist/services/admin/data.service.js +287 -286
- package/dist/services/admin/data.service.js.map +1 -1
- package/dist/services/admin/tenants.service.d.ts.map +1 -1
- package/dist/services/admin/tenants.service.js.map +1 -1
- package/dist/services/auth.service.d.ts +2 -3
- package/dist/services/auth.service.js +16 -16
- package/dist/services/invite.service.d.ts +1 -1
- package/dist/services/invite.service.js +17 -15
- package/dist/services/storage.service.d.ts.map +1 -1
- package/dist/services/storage.service.js +35 -4
- package/dist/services/storage.service.js.map +1 -1
- package/dist/services/system.service.d.ts.map +1 -1
- package/dist/services/system.service.js +1 -1
- package/dist/services/system.service.js.map +1 -1
- package/dist/services/tenant.service.d.ts +1 -1
- package/dist/services/tenant.service.js +43 -31
- package/dist/sse/subscriptions.controller.d.ts +57 -0
- package/dist/sse/subscriptions.controller.d.ts.map +1 -0
- package/dist/sse/subscriptions.controller.js +127 -0
- package/dist/sse/subscriptions.controller.js.map +1 -0
- package/dist/startup/bootstrap.d.ts +13 -2
- package/dist/startup/bootstrap.d.ts.map +1 -1
- package/dist/startup/bootstrap.js +85 -13
- package/dist/startup/bootstrap.js.map +1 -1
- package/dist/storage/s3-backend.d.ts.map +1 -1
- package/dist/storage/s3-backend.js +3 -3
- package/dist/storage/s3-backend.js.map +1 -1
- package/dist/websocket/server.d.ts.map +1 -1
- package/dist/websocket/server.js +14 -3
- package/dist/websocket/server.js.map +1 -1
- package/docker/README.md +309 -11
- package/package.json +214 -210
- package/templates/.env.example +115 -55
- package/templates/archlast.config.js +51 -37
- package/templates/docker-compose.prod.yml +32 -15
- package/templates/docker-compose.yml +117 -33
package/dist/cache/store.js
CHANGED
|
@@ -19,10 +19,29 @@ class CachePartition {
|
|
|
19
19
|
currentSize = 0;
|
|
20
20
|
hits = 0;
|
|
21
21
|
misses = 0;
|
|
22
|
+
evictions = 0;
|
|
23
|
+
writes = 0;
|
|
24
|
+
deletes = 0;
|
|
25
|
+
onEvict;
|
|
22
26
|
constructor(maxBytes = 50 * 1024 * 1024, maxEntries = 0) {
|
|
23
27
|
this.maxBytes = maxBytes;
|
|
24
28
|
this.maxEntries = maxEntries;
|
|
25
29
|
}
|
|
30
|
+
/**
|
|
31
|
+
* Set eviction callback for L1→L2 promotion
|
|
32
|
+
* Called BEFORE entry is removed from L1 cache
|
|
33
|
+
*/
|
|
34
|
+
setEvictionCallback(callback) {
|
|
35
|
+
this.onEvict = callback;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Calculate remaining TTL for an entry
|
|
39
|
+
*/
|
|
40
|
+
calculateRemainingTtl(entry) {
|
|
41
|
+
if (!entry.expiresAt)
|
|
42
|
+
return 0;
|
|
43
|
+
return Math.max(0, entry.expiresAt - Date.now());
|
|
44
|
+
}
|
|
26
45
|
get(key) {
|
|
27
46
|
const entry = this.entries.get(key);
|
|
28
47
|
if (!entry) {
|
|
@@ -59,6 +78,7 @@ class CachePartition {
|
|
|
59
78
|
};
|
|
60
79
|
this.entries.set(key, entry);
|
|
61
80
|
this.currentSize += size;
|
|
81
|
+
this.writes++;
|
|
62
82
|
if (this.maxEntries > 0 && this.entries.size > this.maxEntries) {
|
|
63
83
|
logger_js_1.logger.log({
|
|
64
84
|
timestamp: Date.now(),
|
|
@@ -77,6 +97,7 @@ class CachePartition {
|
|
|
77
97
|
}
|
|
78
98
|
this.entries.delete(key);
|
|
79
99
|
this.currentSize -= entry.size;
|
|
100
|
+
this.deletes++;
|
|
80
101
|
return true;
|
|
81
102
|
}
|
|
82
103
|
clear() {
|
|
@@ -92,6 +113,9 @@ class CachePartition {
|
|
|
92
113
|
entries: this.entries.size,
|
|
93
114
|
hits: this.hits,
|
|
94
115
|
misses: this.misses,
|
|
116
|
+
evictions: this.evictions,
|
|
117
|
+
writes: this.writes,
|
|
118
|
+
deletes: this.deletes,
|
|
95
119
|
};
|
|
96
120
|
}
|
|
97
121
|
evictLRU() {
|
|
@@ -103,8 +127,36 @@ class CachePartition {
|
|
|
103
127
|
oldestKey = key;
|
|
104
128
|
}
|
|
105
129
|
}
|
|
106
|
-
if (oldestKey) {
|
|
130
|
+
if (oldestKey && oldest) {
|
|
131
|
+
// Call eviction callback BEFORE removing from L1
|
|
132
|
+
// This allows L1→L2 promotion before the entry is lost
|
|
133
|
+
if (this.onEvict) {
|
|
134
|
+
const remainingTtl = this.calculateRemainingTtl(oldest);
|
|
135
|
+
// Fire and forget - don't block L1 operations
|
|
136
|
+
try {
|
|
137
|
+
const result = this.onEvict(oldestKey, oldest.value, remainingTtl);
|
|
138
|
+
if (result instanceof Promise) {
|
|
139
|
+
result.catch((err) => {
|
|
140
|
+
logger_js_1.logger.log({
|
|
141
|
+
timestamp: Date.now(),
|
|
142
|
+
level: "warn",
|
|
143
|
+
kind: "cache",
|
|
144
|
+
message: `Eviction callback failed for key ${oldestKey}: ${err}`,
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
catch (err) {
|
|
150
|
+
logger_js_1.logger.log({
|
|
151
|
+
timestamp: Date.now(),
|
|
152
|
+
level: "warn",
|
|
153
|
+
kind: "cache",
|
|
154
|
+
message: `Eviction callback error for key ${oldestKey}: ${err}`,
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
}
|
|
107
158
|
this.delete(oldestKey);
|
|
159
|
+
this.evictions++;
|
|
108
160
|
}
|
|
109
161
|
}
|
|
110
162
|
}
|
|
@@ -129,69 +181,40 @@ class CacheStore {
|
|
|
129
181
|
this.aggregateCache = new CachePartition(aggregateCacheSize, aggregateCacheEntries);
|
|
130
182
|
}
|
|
131
183
|
/**
|
|
132
|
-
* Get
|
|
184
|
+
* Get a cache partition by name
|
|
133
185
|
*/
|
|
134
|
-
|
|
135
|
-
let cache;
|
|
186
|
+
getPartition(partition) {
|
|
136
187
|
switch (partition) {
|
|
137
188
|
case "document":
|
|
138
|
-
|
|
139
|
-
break;
|
|
189
|
+
return this.documentCache;
|
|
140
190
|
case "aggregate":
|
|
141
|
-
|
|
142
|
-
break;
|
|
191
|
+
return this.aggregateCache;
|
|
143
192
|
case "function":
|
|
144
|
-
|
|
145
|
-
break;
|
|
193
|
+
return this.functionCache;
|
|
146
194
|
case "query":
|
|
147
195
|
default:
|
|
148
|
-
|
|
149
|
-
break;
|
|
196
|
+
return this.queryCache;
|
|
150
197
|
}
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Get value from cache
|
|
201
|
+
*/
|
|
202
|
+
get(key, partition = "query") {
|
|
203
|
+
const cache = this.getPartition(partition);
|
|
151
204
|
return cache.get(key);
|
|
152
205
|
}
|
|
153
206
|
/**
|
|
154
207
|
* Set value in cache
|
|
155
208
|
*/
|
|
156
209
|
set(key, value, partition = "query", size, ttl) {
|
|
157
|
-
|
|
158
|
-
switch (partition) {
|
|
159
|
-
case "document":
|
|
160
|
-
cache = this.documentCache;
|
|
161
|
-
break;
|
|
162
|
-
case "aggregate":
|
|
163
|
-
cache = this.aggregateCache;
|
|
164
|
-
break;
|
|
165
|
-
case "function":
|
|
166
|
-
cache = this.functionCache;
|
|
167
|
-
break;
|
|
168
|
-
case "query":
|
|
169
|
-
default:
|
|
170
|
-
cache = this.queryCache;
|
|
171
|
-
break;
|
|
172
|
-
}
|
|
210
|
+
const cache = this.getPartition(partition);
|
|
173
211
|
cache.set(key, value, size, ttl);
|
|
174
212
|
}
|
|
175
213
|
/**
|
|
176
214
|
* Delete specific key
|
|
177
215
|
*/
|
|
178
216
|
delete(key, partition = "query") {
|
|
179
|
-
|
|
180
|
-
switch (partition) {
|
|
181
|
-
case "document":
|
|
182
|
-
cache = this.documentCache;
|
|
183
|
-
break;
|
|
184
|
-
case "aggregate":
|
|
185
|
-
cache = this.aggregateCache;
|
|
186
|
-
break;
|
|
187
|
-
case "function":
|
|
188
|
-
cache = this.functionCache;
|
|
189
|
-
break;
|
|
190
|
-
case "query":
|
|
191
|
-
default:
|
|
192
|
-
cache = this.queryCache;
|
|
193
|
-
break;
|
|
194
|
-
}
|
|
217
|
+
const cache = this.getPartition(partition);
|
|
195
218
|
return cache.delete(key);
|
|
196
219
|
}
|
|
197
220
|
/**
|
|
@@ -224,22 +247,7 @@ class CacheStore {
|
|
|
224
247
|
* Invalidate keys matching pattern
|
|
225
248
|
*/
|
|
226
249
|
invalidatePattern(pattern, partition = "query") {
|
|
227
|
-
|
|
228
|
-
switch (partition) {
|
|
229
|
-
case "document":
|
|
230
|
-
cache = this.documentCache;
|
|
231
|
-
break;
|
|
232
|
-
case "aggregate":
|
|
233
|
-
cache = this.aggregateCache;
|
|
234
|
-
break;
|
|
235
|
-
case "function":
|
|
236
|
-
cache = this.functionCache;
|
|
237
|
-
break;
|
|
238
|
-
case "query":
|
|
239
|
-
default:
|
|
240
|
-
cache = this.queryCache;
|
|
241
|
-
break;
|
|
242
|
-
}
|
|
250
|
+
const cache = this.getPartition(partition);
|
|
243
251
|
const invalidated = [];
|
|
244
252
|
// Convert glob pattern to regex
|
|
245
253
|
const regexPattern = pattern.replace(/\*/g, ".*").replace(/\?/g, ".");
|
|
@@ -268,22 +276,7 @@ class CacheStore {
|
|
|
268
276
|
*/
|
|
269
277
|
clear(partition) {
|
|
270
278
|
if (partition) {
|
|
271
|
-
|
|
272
|
-
switch (partition) {
|
|
273
|
-
case "document":
|
|
274
|
-
cache = this.documentCache;
|
|
275
|
-
break;
|
|
276
|
-
case "aggregate":
|
|
277
|
-
cache = this.aggregateCache;
|
|
278
|
-
break;
|
|
279
|
-
case "function":
|
|
280
|
-
cache = this.functionCache;
|
|
281
|
-
break;
|
|
282
|
-
case "query":
|
|
283
|
-
default:
|
|
284
|
-
cache = this.queryCache;
|
|
285
|
-
break;
|
|
286
|
-
}
|
|
279
|
+
const cache = this.getPartition(partition);
|
|
287
280
|
cache.clear();
|
|
288
281
|
}
|
|
289
282
|
else {
|
package/dist/cache/store.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/cache/store.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/cache/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,10 +8,12 @@
|
|
|
8
8
|
* 4. Write-Back (Write-Behind)
|
|
9
9
|
* 5. Write-Around
|
|
10
10
|
*/
|
|
11
|
+
export type { CacheLayerStats, RedisStats, LegacyCacheStats as CacheStats } from "./types.js";
|
|
11
12
|
export type CacheStrategy = "cache-aside" | "read-through" | "write-through" | "write-back" | "write-around";
|
|
12
13
|
export interface CacheConfig {
|
|
13
14
|
strategy: CacheStrategy;
|
|
14
15
|
ttl?: number;
|
|
16
|
+
l2Ttl?: number;
|
|
15
17
|
maxSize?: number;
|
|
16
18
|
writeBackDelay?: number;
|
|
17
19
|
enableInvalidation?: boolean;
|
|
@@ -30,15 +32,6 @@ export interface CacheEntry<T> {
|
|
|
30
32
|
data: T;
|
|
31
33
|
metadata: CacheMetadata;
|
|
32
34
|
}
|
|
33
|
-
export interface CacheStats {
|
|
34
|
-
hits: number;
|
|
35
|
-
misses: number;
|
|
36
|
-
evictions: number;
|
|
37
|
-
writes: number;
|
|
38
|
-
deletes: number;
|
|
39
|
-
size: number;
|
|
40
|
-
hitRate: number;
|
|
41
|
-
}
|
|
42
35
|
/**
|
|
43
36
|
* Invalidation strategies
|
|
44
37
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"strategies.d.ts","sourceRoot":"","sources":["../../src/cache/strategies.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;
|
|
1
|
+
{"version":3,"file":"strategies.d.ts","sourceRoot":"","sources":["../../src/cache/strategies.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,YAAY,EAAE,eAAe,EAAE,UAAU,EAAE,gBAAgB,IAAI,UAAU,EAAE,MAAM,YAAY,CAAC;AAE9F,MAAM,MAAM,aAAa,GACnB,aAAa,GACb,cAAc,GACd,eAAe,GACf,YAAY,GACZ,cAAc,CAAC;AAErB,MAAM,WAAW,WAAW;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,oBAAoB,CAAC,EAAE,MAAM,EAAE,CAAC;IAChC,SAAS,CAAC,EAAE,OAAO,GAAG,UAAU,GAAG,UAAU,GAAG,WAAW,CAAC;CAC/D;AAED,MAAM,WAAW,aAAa;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,UAAU,CAAC,CAAC;IACzB,IAAI,EAAE,CAAC,CAAC;IACR,QAAQ,EAAE,aAAa,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAC1B,KAAK,GACL,KAAK,GACL,KAAK,GACL,SAAS,GACT,YAAY,CAAC;AAEnB,MAAM,WAAW,kBAAkB;IAC/B,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;CACvB"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Cache Statistics Types
|
|
3
|
+
*
|
|
4
|
+
* Single source of truth for cache stats across the codebase.
|
|
5
|
+
* Replaces fragmented CacheStats definitions from protocol.ts, strategies.ts, and store.ts.
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Complete cache layer statistics - unified interface
|
|
9
|
+
*
|
|
10
|
+
* This interface represents the full set of statistics that should be available
|
|
11
|
+
* for each cache layer (document, query, aggregate, function).
|
|
12
|
+
*/
|
|
13
|
+
export interface CacheLayerStats {
|
|
14
|
+
/** Display name (added by frontend/system function) */
|
|
15
|
+
name?: string;
|
|
16
|
+
/** Number of cache hits */
|
|
17
|
+
hits: number;
|
|
18
|
+
/** Number of cache misses */
|
|
19
|
+
misses: number;
|
|
20
|
+
/** Pre-calculated hit rate (0-1 ratio) */
|
|
21
|
+
hitRate: number;
|
|
22
|
+
/** Number of entries evicted from cache */
|
|
23
|
+
evictions: number;
|
|
24
|
+
/** Number of write operations */
|
|
25
|
+
writes: number;
|
|
26
|
+
/** Number of delete operations */
|
|
27
|
+
deletes: number;
|
|
28
|
+
/** Memory size in BYTES */
|
|
29
|
+
size: number;
|
|
30
|
+
/** Entry count (for progress bar display) */
|
|
31
|
+
entries: number;
|
|
32
|
+
/** Max entries (config limit) */
|
|
33
|
+
maxSize: number;
|
|
34
|
+
/** Max bytes (optional, for memory tracking) */
|
|
35
|
+
maxBytes?: number;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Redis L2 cache statistics
|
|
39
|
+
*/
|
|
40
|
+
export interface RedisStats {
|
|
41
|
+
/** Whether Redis is connected */
|
|
42
|
+
connected: boolean;
|
|
43
|
+
/** Number of cache hits */
|
|
44
|
+
hits: number;
|
|
45
|
+
/** Number of cache misses */
|
|
46
|
+
misses: number;
|
|
47
|
+
/** Hit rate (0-1 ratio) */
|
|
48
|
+
hitRate: number;
|
|
49
|
+
/** Memory used in bytes */
|
|
50
|
+
memoryUsed: number;
|
|
51
|
+
/** Number of connected clients */
|
|
52
|
+
connectedClients: number;
|
|
53
|
+
/** Number of evictions */
|
|
54
|
+
evictions: number;
|
|
55
|
+
/** Operations per second */
|
|
56
|
+
opsPerSec: number;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Full cache stats response from introspection API
|
|
60
|
+
*
|
|
61
|
+
* Includes stats for all L1 cache layers plus optional L2 Redis stats.
|
|
62
|
+
*/
|
|
63
|
+
export interface FullCacheStats {
|
|
64
|
+
/** Document cache stats */
|
|
65
|
+
document: CacheLayerStats;
|
|
66
|
+
/** Query cache stats */
|
|
67
|
+
query: CacheLayerStats;
|
|
68
|
+
/** Aggregate cache stats */
|
|
69
|
+
aggregate: CacheLayerStats;
|
|
70
|
+
/** Function cache stats (optional) */
|
|
71
|
+
function?: CacheLayerStats;
|
|
72
|
+
/** Dependency tracking stats (optional) */
|
|
73
|
+
dependencies?: {
|
|
74
|
+
entries: number;
|
|
75
|
+
};
|
|
76
|
+
/** Cache sidecar uptime in milliseconds (optional) */
|
|
77
|
+
uptime?: number;
|
|
78
|
+
/** Redis L2 cache stats (optional) */
|
|
79
|
+
redis?: RedisStats;
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Legacy CacheStats from strategies.ts
|
|
83
|
+
*
|
|
84
|
+
* @deprecated Use CacheLayerStats instead
|
|
85
|
+
* This is kept for backward compatibility with CacheManager
|
|
86
|
+
*/
|
|
87
|
+
export interface LegacyCacheStats {
|
|
88
|
+
hits: number;
|
|
89
|
+
misses: number;
|
|
90
|
+
evictions: number;
|
|
91
|
+
writes: number;
|
|
92
|
+
deletes: number;
|
|
93
|
+
size: number;
|
|
94
|
+
hitRate: number;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Legacy CacheStats from store.ts
|
|
98
|
+
*
|
|
99
|
+
* @deprecated Use CacheLayerStats instead
|
|
100
|
+
* This is kept for backward compatibility with CacheStore
|
|
101
|
+
*/
|
|
102
|
+
export interface StoreCacheStats {
|
|
103
|
+
size: number;
|
|
104
|
+
maxSize: number;
|
|
105
|
+
maxBytes: number;
|
|
106
|
+
maxEntries: number;
|
|
107
|
+
entries: number;
|
|
108
|
+
hits: number;
|
|
109
|
+
misses: number;
|
|
110
|
+
evictions: number;
|
|
111
|
+
writes: number;
|
|
112
|
+
deletes: number;
|
|
113
|
+
hitRate: number;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Default empty stats for a cache layer
|
|
117
|
+
*
|
|
118
|
+
* @param maxSize - Max entries for this layer
|
|
119
|
+
* @returns Empty CacheLayerStats object
|
|
120
|
+
*/
|
|
121
|
+
export declare function getEmptyCacheLayerStats(maxSize: number): CacheLayerStats;
|
|
122
|
+
/**
|
|
123
|
+
* Convert legacy CacheStats to CacheLayerStats
|
|
124
|
+
*
|
|
125
|
+
* @param stats - Legacy stats object or Promise of stats
|
|
126
|
+
* @param maxSize - Max entries for this layer
|
|
127
|
+
* @returns Unified CacheLayerStats
|
|
128
|
+
*/
|
|
129
|
+
export declare function toCacheLayerStats(stats: LegacyCacheStats | StoreCacheStats | Promise<LegacyCacheStats | StoreCacheStats>, maxSize: number): CacheLayerStats | Promise<CacheLayerStats>;
|
|
130
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/cache/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;;;;GAKG;AACH,MAAM,WAAW,eAAe;IAC5B,uDAAuD;IACvD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,6BAA6B;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,0CAA0C;IAC1C,OAAO,EAAE,MAAM,CAAC;IAChB,2CAA2C;IAC3C,SAAS,EAAE,MAAM,CAAC;IAClB,iCAAiC;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,kCAAkC;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,6CAA6C;IAC7C,OAAO,EAAE,MAAM,CAAC;IAChB,iCAAiC;IACjC,OAAO,EAAE,MAAM,CAAC;IAChB,gDAAgD;IAChD,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACvB,iCAAiC;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,6BAA6B;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,2BAA2B;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,2BAA2B;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,kCAAkC;IAClC,gBAAgB,EAAE,MAAM,CAAC;IACzB,0BAA0B;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,4BAA4B;IAC5B,SAAS,EAAE,MAAM,CAAC;CACrB;AAED;;;;GAIG;AACH,MAAM,WAAW,cAAc;IAC3B,2BAA2B;IAC3B,QAAQ,EAAE,eAAe,CAAC;IAC1B,wBAAwB;IACxB,KAAK,EAAE,eAAe,CAAC;IACvB,4BAA4B;IAC5B,SAAS,EAAE,eAAe,CAAC;IAC3B,sCAAsC;IACtC,QAAQ,CAAC,EAAE,eAAe,CAAC;IAC3B,2CAA2C;IAC3C,YAAY,CAAC,EAAE;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,sDAAsD;IACtD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,sCAAsC;IACtC,KAAK,CAAC,EAAE,UAAU,CAAC;CACtB;AAED;;;;;GAKG;AACH,MAAM,WAAW,gBAAgB;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;CACnB;AAED;;;;;GAKG;AACH,MAAM,WAAW,eAAe;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACnB;AAED;;;;;GAKG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe,CAYxE;AAED;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,eAAe,GAAG,OAAO,CAAC,gBAAgB,GAAG,eAAe,CAAC,EACvF,OAAO,EAAE,MAAM,GAChB,eAAe,GAAG,OAAO,CAAC,eAAe,CAAC,CAM5C"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Unified Cache Statistics Types
|
|
4
|
+
*
|
|
5
|
+
* Single source of truth for cache stats across the codebase.
|
|
6
|
+
* Replaces fragmented CacheStats definitions from protocol.ts, strategies.ts, and store.ts.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.getEmptyCacheLayerStats = getEmptyCacheLayerStats;
|
|
10
|
+
exports.toCacheLayerStats = toCacheLayerStats;
|
|
11
|
+
/**
|
|
12
|
+
* Default empty stats for a cache layer
|
|
13
|
+
*
|
|
14
|
+
* @param maxSize - Max entries for this layer
|
|
15
|
+
* @returns Empty CacheLayerStats object
|
|
16
|
+
*/
|
|
17
|
+
function getEmptyCacheLayerStats(maxSize) {
|
|
18
|
+
return {
|
|
19
|
+
hits: 0,
|
|
20
|
+
misses: 0,
|
|
21
|
+
hitRate: 0,
|
|
22
|
+
evictions: 0,
|
|
23
|
+
writes: 0,
|
|
24
|
+
deletes: 0,
|
|
25
|
+
size: 0,
|
|
26
|
+
entries: 0,
|
|
27
|
+
maxSize,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Convert legacy CacheStats to CacheLayerStats
|
|
32
|
+
*
|
|
33
|
+
* @param stats - Legacy stats object or Promise of stats
|
|
34
|
+
* @param maxSize - Max entries for this layer
|
|
35
|
+
* @returns Unified CacheLayerStats
|
|
36
|
+
*/
|
|
37
|
+
function toCacheLayerStats(stats, maxSize) {
|
|
38
|
+
// Handle async return from CacheManager.getStats()
|
|
39
|
+
if (stats instanceof Promise) {
|
|
40
|
+
return stats.then(s => toCacheLayerStatsSync(s, maxSize));
|
|
41
|
+
}
|
|
42
|
+
return toCacheLayerStatsSync(stats, maxSize);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Synchronous convert legacy CacheStats to CacheLayerStats
|
|
46
|
+
*/
|
|
47
|
+
function toCacheLayerStatsSync(stats, maxSize) {
|
|
48
|
+
return {
|
|
49
|
+
hits: stats.hits,
|
|
50
|
+
misses: stats.misses,
|
|
51
|
+
hitRate: stats.hitRate,
|
|
52
|
+
evictions: stats.evictions,
|
|
53
|
+
writes: stats.writes,
|
|
54
|
+
deletes: stats.deletes,
|
|
55
|
+
size: stats.size,
|
|
56
|
+
entries: 'entries' in stats ? stats.entries : 0,
|
|
57
|
+
maxSize,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/cache/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;AAuHH,0DAYC;AASD,8CASC;AApCD;;;;;GAKG;AACH,SAAgB,uBAAuB,CAAC,OAAe;IACnD,OAAO;QACH,IAAI,EAAE,CAAC;QACP,MAAM,EAAE,CAAC;QACT,OAAO,EAAE,CAAC;QACV,SAAS,EAAE,CAAC;QACZ,MAAM,EAAE,CAAC;QACT,OAAO,EAAE,CAAC;QACV,IAAI,EAAE,CAAC;QACP,OAAO,EAAE,CAAC;QACV,OAAO;KACV,CAAC;AACN,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,iBAAiB,CAC7B,KAAuF,EACvF,OAAe;IAEf,mDAAmD;IACnD,IAAI,KAAK,YAAY,OAAO,EAAE,CAAC;QAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;IAC9D,CAAC;IACD,OAAO,qBAAqB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;AACjD,CAAC;AAED;;GAEG;AACH,SAAS,qBAAqB,CAC1B,KAAyC,EACzC,OAAe;IAEf,OAAO;QACH,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,OAAO,EAAE,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC/C,OAAO;KACV,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { BullMQConfig } from "./schema.js";
|
|
2
|
+
/**
|
|
3
|
+
* Build BullMQ configuration from environment variables.
|
|
4
|
+
* Falls back to REDIS_* variables for Redis connection if BULLMQ_REDIS_* not set.
|
|
5
|
+
*/
|
|
6
|
+
export declare function getBullMQConfig(): BullMQConfig;
|
|
7
|
+
/**
|
|
8
|
+
* Check if BullMQ is enabled via environment variable.
|
|
9
|
+
*/
|
|
10
|
+
export declare function isBullMQEnabled(): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Default BullMQ configuration object.
|
|
13
|
+
* Useful for testing and as a reference for all defaults.
|
|
14
|
+
*/
|
|
15
|
+
export declare const defaultBullMQConfig: BullMQConfig;
|
|
16
|
+
//# sourceMappingURL=bullmq.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bullmq.d.ts","sourceRoot":"","sources":["../../src/config/bullmq.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD;;;GAGG;AACH,wBAAgB,eAAe,IAAI,YAAY,CA0C9C;AAED;;GAEG;AACH,wBAAgB,eAAe,IAAI,OAAO,CAEzC;AAED;;;GAGG;AACH,eAAO,MAAM,mBAAmB,EAAE,YAuCjC,CAAC"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.defaultBullMQConfig = void 0;
|
|
4
|
+
exports.getBullMQConfig = getBullMQConfig;
|
|
5
|
+
exports.isBullMQEnabled = isBullMQEnabled;
|
|
6
|
+
/**
|
|
7
|
+
* Build BullMQ configuration from environment variables.
|
|
8
|
+
* Falls back to REDIS_* variables for Redis connection if BULLMQ_REDIS_* not set.
|
|
9
|
+
*/
|
|
10
|
+
function getBullMQConfig() {
|
|
11
|
+
return {
|
|
12
|
+
enabled: process.env.BULLMQ_ENABLED !== "false",
|
|
13
|
+
redis: {
|
|
14
|
+
host: process.env.BULLMQ_REDIS_HOST || process.env.REDIS_HOST || "localhost",
|
|
15
|
+
port: parseInt(process.env.BULLMQ_REDIS_PORT || process.env.REDIS_PORT || "6379"),
|
|
16
|
+
password: process.env.BULLMQ_REDIS_PASSWORD || process.env.REDIS_PASSWORD,
|
|
17
|
+
db: parseInt(process.env.BULLMQ_REDIS_DB || "1"),
|
|
18
|
+
},
|
|
19
|
+
queue: {
|
|
20
|
+
name: process.env.JOB_QUEUE_NAME || "archlast-jobs",
|
|
21
|
+
prefix: process.env.BULLMQ_KEY_PREFIX || "bull",
|
|
22
|
+
},
|
|
23
|
+
worker: {
|
|
24
|
+
concurrency: parseInt(process.env.JOB_WORKER_CONCURRENCY || "5"),
|
|
25
|
+
lockDuration: parseInt(process.env.JOB_LOCK_DURATION || "30000"),
|
|
26
|
+
gracePeriod: parseInt(process.env.JOB_WORKER_GRACE_PERIOD || "30000"),
|
|
27
|
+
threads: parseInt(process.env.JOB_WORKER_THREADS || "1"),
|
|
28
|
+
},
|
|
29
|
+
scheduler: {
|
|
30
|
+
checkInterval: parseInt(process.env.BULLMQ_SCHEDULER_CHECK_INTERVAL || "60000"),
|
|
31
|
+
},
|
|
32
|
+
circuitBreaker: {
|
|
33
|
+
enabled: process.env.JOB_CIRCUIT_BREAKER_ENABLED === "true",
|
|
34
|
+
failureThreshold: parseInt(process.env.JOB_CIRCUIT_BREAKER_FAILURE_THRESHOLD || "5"),
|
|
35
|
+
successThreshold: parseInt(process.env.JOB_CIRCUIT_BREAKER_SUCCESS_THRESHOLD || "2"),
|
|
36
|
+
resetTimeoutMs: parseInt(process.env.JOB_CIRCUIT_BREAKER_RESET_TIMEOUT_MS || "30000"),
|
|
37
|
+
halfOpenMaxCalls: parseInt(process.env.JOB_CIRCUIT_BREAKER_HALF_OPEN_MAX_CALLS || "3"),
|
|
38
|
+
},
|
|
39
|
+
priorityAging: {
|
|
40
|
+
enabled: process.env.BULLMQ_PRIORITY_AGING_ENABLED !== "false",
|
|
41
|
+
checkIntervalMs: parseInt(process.env.BULLMQ_AGING_CHECK_INTERVAL || "60000"),
|
|
42
|
+
maxJobsPerCheck: parseInt(process.env.BULLMQ_AGING_MAX_JOBS || "100"),
|
|
43
|
+
},
|
|
44
|
+
dlq: {
|
|
45
|
+
retentionDays: parseInt(process.env.BULLMQ_DLQ_RETENTION_DAYS || "30"),
|
|
46
|
+
},
|
|
47
|
+
metrics: {
|
|
48
|
+
enabled: process.env.BULLMQ_METRICS_ENABLED !== "false",
|
|
49
|
+
updateIntervalMs: parseInt(process.env.BULLMQ_METRICS_INTERVAL || "10000"),
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Check if BullMQ is enabled via environment variable.
|
|
55
|
+
*/
|
|
56
|
+
function isBullMQEnabled() {
|
|
57
|
+
return process.env.BULLMQ_ENABLED !== "false";
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Default BullMQ configuration object.
|
|
61
|
+
* Useful for testing and as a reference for all defaults.
|
|
62
|
+
*/
|
|
63
|
+
exports.defaultBullMQConfig = {
|
|
64
|
+
enabled: true,
|
|
65
|
+
redis: {
|
|
66
|
+
host: "localhost",
|
|
67
|
+
port: 6379,
|
|
68
|
+
db: 1,
|
|
69
|
+
},
|
|
70
|
+
queue: {
|
|
71
|
+
name: "archlast-jobs",
|
|
72
|
+
prefix: "bull",
|
|
73
|
+
},
|
|
74
|
+
worker: {
|
|
75
|
+
concurrency: 5,
|
|
76
|
+
lockDuration: 30000,
|
|
77
|
+
gracePeriod: 30000,
|
|
78
|
+
threads: 1,
|
|
79
|
+
},
|
|
80
|
+
scheduler: {
|
|
81
|
+
checkInterval: 60000,
|
|
82
|
+
},
|
|
83
|
+
circuitBreaker: {
|
|
84
|
+
enabled: false,
|
|
85
|
+
failureThreshold: 5,
|
|
86
|
+
successThreshold: 2,
|
|
87
|
+
resetTimeoutMs: 30000,
|
|
88
|
+
halfOpenMaxCalls: 3,
|
|
89
|
+
},
|
|
90
|
+
priorityAging: {
|
|
91
|
+
enabled: true,
|
|
92
|
+
checkIntervalMs: 60000,
|
|
93
|
+
maxJobsPerCheck: 100,
|
|
94
|
+
},
|
|
95
|
+
dlq: {
|
|
96
|
+
retentionDays: 30,
|
|
97
|
+
},
|
|
98
|
+
metrics: {
|
|
99
|
+
enabled: true,
|
|
100
|
+
updateIntervalMs: 10000,
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
//# sourceMappingURL=bullmq.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bullmq.js","sourceRoot":"","sources":["../../src/config/bullmq.ts"],"names":[],"mappings":"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"}
|
package/dist/config/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC"}
|
package/dist/config/index.js
CHANGED
|
@@ -17,4 +17,5 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./paths.js"), exports);
|
|
18
18
|
__exportStar(require("./schema.js"), exports);
|
|
19
19
|
__exportStar(require("./service.js"), exports);
|
|
20
|
+
__exportStar(require("./bullmq.js"), exports);
|
|
20
21
|
//# sourceMappingURL=index.js.map
|
package/dist/config/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,8CAA4B;AAC5B,+CAA6B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,8CAA4B;AAC5B,+CAA6B;AAC7B,8CAA4B"}
|