@powerhousedao/reactor 5.0.3 → 5.0.5
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/dist/src/cache/index.d.ts +3 -0
- package/dist/src/cache/index.d.ts.map +1 -0
- package/dist/src/cache/index.js +2 -0
- package/dist/src/cache/index.js.map +1 -0
- package/dist/src/cache/kysely-operation-index.d.ts +13 -0
- package/dist/src/cache/kysely-operation-index.d.ts.map +1 -0
- package/dist/src/cache/kysely-operation-index.js +207 -0
- package/dist/src/cache/kysely-operation-index.js.map +1 -0
- package/dist/src/cache/kysely-write-cache.d.ts +5 -4
- package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
- package/dist/src/cache/kysely-write-cache.js +12 -12
- package/dist/src/cache/kysely-write-cache.js.map +1 -1
- package/dist/src/cache/operation-index-types.d.ts +49 -0
- package/dist/src/cache/operation-index-types.d.ts.map +1 -0
- package/dist/src/cache/operation-index-types.js +4 -0
- package/dist/src/cache/operation-index-types.js.map +1 -0
- package/dist/src/cache/{types.d.ts → write-cache-types.d.ts} +1 -1
- package/dist/src/cache/write-cache-types.d.ts.map +1 -0
- package/dist/src/cache/write-cache-types.js +2 -0
- package/dist/src/cache/write-cache-types.js.map +1 -0
- package/dist/src/client/reactor-client.d.ts +6 -4
- package/dist/src/client/reactor-client.d.ts.map +1 -1
- package/dist/src/client/reactor-client.js +118 -37
- package/dist/src/client/reactor-client.js.map +1 -1
- package/dist/src/client/types.d.ts +4 -4
- package/dist/src/client/types.d.ts.map +1 -1
- package/dist/src/core/builder.d.ts +15 -2
- package/dist/src/core/builder.d.ts.map +1 -1
- package/dist/src/core/builder.js +48 -7
- package/dist/src/core/builder.js.map +1 -1
- package/dist/src/core/reactor-builder.d.ts +40 -0
- package/dist/src/core/reactor-builder.d.ts.map +1 -0
- package/dist/src/core/reactor-builder.js +141 -0
- package/dist/src/core/reactor-builder.js.map +1 -0
- package/dist/src/core/reactor.d.ts +36 -11
- package/dist/src/core/reactor.d.ts.map +1 -1
- package/dist/src/core/reactor.js +609 -279
- package/dist/src/core/reactor.js.map +1 -1
- package/dist/src/core/types.d.ts +84 -7
- package/dist/src/core/types.d.ts.map +1 -1
- package/dist/src/core/utils.d.ts +44 -4
- package/dist/src/core/utils.d.ts.map +1 -1
- package/dist/src/core/utils.js +116 -6
- package/dist/src/core/utils.js.map +1 -1
- package/dist/src/events/types.d.ts +28 -0
- package/dist/src/events/types.d.ts.map +1 -1
- package/dist/src/events/types.js +2 -0
- package/dist/src/events/types.js.map +1 -1
- package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
- package/dist/src/executor/simple-job-executor-manager.js +19 -1
- package/dist/src/executor/simple-job-executor-manager.js.map +1 -1
- package/dist/src/executor/simple-job-executor.d.ts +16 -2
- package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
- package/dist/src/executor/simple-job-executor.js +458 -252
- package/dist/src/executor/simple-job-executor.js.map +1 -1
- package/dist/src/executor/types.d.ts +2 -0
- package/dist/src/executor/types.d.ts.map +1 -1
- package/dist/src/executor/types.js.map +1 -1
- package/dist/src/executor/util.d.ts +18 -0
- package/dist/src/executor/util.d.ts.map +1 -1
- package/dist/src/executor/util.js +42 -1
- package/dist/src/executor/util.js.map +1 -1
- package/dist/src/index.d.ts +12 -7
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +9 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/job-tracker/in-memory-job-tracker.d.ts +10 -1
- package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -1
- package/dist/src/job-tracker/in-memory-job-tracker.js +57 -23
- package/dist/src/job-tracker/in-memory-job-tracker.js.map +1 -1
- package/dist/src/job-tracker/interfaces.d.ts +5 -7
- package/dist/src/job-tracker/interfaces.d.ts.map +1 -1
- package/dist/src/queue/types.d.ts +6 -1
- package/dist/src/queue/types.d.ts.map +1 -1
- package/dist/src/queue/types.js.map +1 -1
- package/dist/src/read-models/coordinator.d.ts.map +1 -1
- package/dist/src/read-models/coordinator.js +11 -0
- package/dist/src/read-models/coordinator.js.map +1 -1
- package/dist/src/read-models/document-view.d.ts +11 -6
- package/dist/src/read-models/document-view.d.ts.map +1 -1
- package/dist/src/read-models/document-view.js +156 -113
- package/dist/src/read-models/document-view.js.map +1 -1
- package/dist/src/read-models/types.d.ts +3 -3
- package/dist/src/read-models/types.d.ts.map +1 -1
- package/dist/src/shared/awaiter.d.ts +11 -8
- package/dist/src/shared/awaiter.d.ts.map +1 -1
- package/dist/src/shared/awaiter.js +66 -75
- package/dist/src/shared/awaiter.js.map +1 -1
- package/dist/src/shared/consistency-tracker.d.ts +48 -0
- package/dist/src/shared/consistency-tracker.d.ts.map +1 -0
- package/dist/src/shared/consistency-tracker.js +123 -0
- package/dist/src/shared/consistency-tracker.js.map +1 -0
- package/dist/src/shared/types.d.ts +30 -2
- package/dist/src/shared/types.d.ts.map +1 -1
- package/dist/src/shared/types.js +4 -2
- package/dist/src/shared/types.js.map +1 -1
- package/dist/src/storage/index.d.ts +4 -0
- package/dist/src/storage/index.d.ts.map +1 -0
- package/dist/src/storage/index.js +3 -0
- package/dist/src/storage/index.js.map +1 -0
- package/dist/src/storage/interfaces.d.ts +227 -2
- package/dist/src/storage/interfaces.d.ts.map +1 -1
- package/dist/src/storage/interfaces.js.map +1 -1
- package/dist/src/storage/kysely/document-indexer.d.ts +28 -0
- package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -0
- package/dist/src/storage/kysely/document-indexer.js +350 -0
- package/dist/src/storage/kysely/document-indexer.js.map +1 -0
- package/dist/src/storage/kysely/keyframe-store.d.ts.map +1 -1
- package/dist/src/storage/kysely/keyframe-store.js +6 -13
- package/dist/src/storage/kysely/keyframe-store.js.map +1 -1
- package/dist/src/storage/kysely/store.js +1 -1
- package/dist/src/storage/kysely/store.js.map +1 -1
- package/dist/src/storage/kysely/sync-cursor-storage.d.ts +13 -0
- package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -0
- package/dist/src/storage/kysely/sync-cursor-storage.js +93 -0
- package/dist/src/storage/kysely/sync-cursor-storage.js.map +1 -0
- package/dist/src/storage/kysely/sync-remote-storage.d.ts +13 -0
- package/dist/src/storage/kysely/sync-remote-storage.d.ts.map +1 -0
- package/dist/src/storage/kysely/sync-remote-storage.js +134 -0
- package/dist/src/storage/kysely/sync-remote-storage.js.map +1 -0
- package/dist/src/storage/kysely/types.d.ts +98 -2
- package/dist/src/storage/kysely/types.d.ts.map +1 -1
- package/dist/src/storage/migrations/001_create_operation_table.d.ts +3 -0
- package/dist/src/storage/migrations/001_create_operation_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/001_create_operation_table.js +40 -0
- package/dist/src/storage/migrations/001_create_operation_table.js.map +1 -0
- package/dist/src/storage/migrations/002_create_keyframe_table.d.ts +3 -0
- package/dist/src/storage/migrations/002_create_keyframe_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/002_create_keyframe_table.js +27 -0
- package/dist/src/storage/migrations/002_create_keyframe_table.js.map +1 -0
- package/dist/src/storage/migrations/003_create_document_table.d.ts +3 -0
- package/dist/src/storage/migrations/003_create_document_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/003_create_document_table.js +10 -0
- package/dist/src/storage/migrations/003_create_document_table.js.map +1 -0
- package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts +3 -0
- package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/004_create_document_relationship_table.js +35 -0
- package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +1 -0
- package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts +3 -0
- package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/005_create_indexer_state_table.js +10 -0
- package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +1 -0
- package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts +3 -0
- package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js +49 -0
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +1 -0
- package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts +3 -0
- package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js +24 -0
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +1 -0
- package/dist/src/storage/migrations/008_create_view_state_table.d.ts +3 -0
- package/dist/src/storage/migrations/008_create_view_state_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/008_create_view_state_table.js +9 -0
- package/dist/src/storage/migrations/008_create_view_state_table.js.map +1 -0
- package/dist/src/storage/migrations/009_create_operation_index_tables.d.ts +3 -0
- package/dist/src/storage/migrations/009_create_operation_index_tables.d.ts.map +1 -0
- package/dist/src/storage/migrations/009_create_operation_index_tables.js +50 -0
- package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +1 -0
- package/dist/src/storage/migrations/010_create_sync_tables.d.ts +3 -0
- package/dist/src/storage/migrations/010_create_sync_tables.d.ts.map +1 -0
- package/dist/src/storage/migrations/010_create_sync_tables.js +43 -0
- package/dist/src/storage/migrations/010_create_sync_tables.js.map +1 -0
- package/dist/src/storage/migrations/index.d.ts +3 -0
- package/dist/src/storage/migrations/index.d.ts.map +1 -0
- package/dist/src/storage/migrations/index.js +3 -0
- package/dist/src/storage/migrations/index.js.map +1 -0
- package/dist/src/storage/migrations/migrator.d.ts +5 -0
- package/dist/src/storage/migrations/migrator.d.ts.map +1 -0
- package/dist/src/storage/migrations/migrator.js +55 -0
- package/dist/src/storage/migrations/migrator.js.map +1 -0
- package/dist/src/storage/migrations/run-migrations.d.ts +2 -0
- package/dist/src/storage/migrations/run-migrations.d.ts.map +1 -0
- package/dist/src/storage/migrations/run-migrations.js +58 -0
- package/dist/src/storage/migrations/run-migrations.js.map +1 -0
- package/dist/src/storage/migrations/types.d.ts +9 -0
- package/dist/src/storage/migrations/types.d.ts.map +1 -0
- package/dist/src/storage/migrations/types.js.map +1 -0
- package/dist/src/storage/txn.d.ts.map +1 -1
- package/dist/src/storage/txn.js +2 -0
- package/dist/src/storage/txn.js.map +1 -1
- package/dist/src/sync/channels/index.d.ts +3 -0
- package/dist/src/sync/channels/index.d.ts.map +1 -0
- package/dist/src/sync/channels/index.js +3 -0
- package/dist/src/sync/channels/index.js.map +1 -0
- package/dist/src/sync/channels/internal-channel.d.ts +57 -0
- package/dist/src/sync/channels/internal-channel.d.ts.map +1 -0
- package/dist/src/sync/channels/internal-channel.js +106 -0
- package/dist/src/sync/channels/internal-channel.js.map +1 -0
- package/dist/src/sync/channels/utils.d.ts +15 -0
- package/dist/src/sync/channels/utils.d.ts.map +1 -0
- package/dist/src/sync/channels/utils.js +26 -0
- package/dist/src/sync/channels/utils.js.map +1 -0
- package/dist/src/sync/errors.d.ts +10 -0
- package/dist/src/sync/errors.d.ts.map +1 -0
- package/dist/src/sync/errors.js +17 -0
- package/dist/src/sync/errors.js.map +1 -0
- package/dist/src/sync/index.d.ts +12 -0
- package/dist/src/sync/index.d.ts.map +1 -0
- package/dist/src/sync/index.js +9 -0
- package/dist/src/sync/index.js.map +1 -0
- package/dist/src/sync/interfaces.d.ts +150 -0
- package/dist/src/sync/interfaces.d.ts.map +1 -0
- package/dist/src/sync/interfaces.js +2 -0
- package/dist/src/sync/interfaces.js.map +1 -0
- package/dist/src/sync/mailbox.d.ts +21 -0
- package/dist/src/sync/mailbox.d.ts.map +1 -0
- package/dist/src/sync/mailbox.js +59 -0
- package/dist/src/sync/mailbox.js.map +1 -0
- package/dist/src/sync/sync-builder.d.ts +17 -0
- package/dist/src/sync/sync-builder.d.ts.map +1 -0
- package/dist/src/sync/sync-builder.js +29 -0
- package/dist/src/sync/sync-builder.js.map +1 -0
- package/dist/src/sync/sync-manager.d.ts +33 -0
- package/dist/src/sync/sync-manager.d.ts.map +1 -0
- package/dist/src/sync/sync-manager.js +197 -0
- package/dist/src/sync/sync-manager.js.map +1 -0
- package/dist/src/sync/sync-operation.d.ts +28 -0
- package/dist/src/sync/sync-operation.d.ts.map +1 -0
- package/dist/src/sync/sync-operation.js +63 -0
- package/dist/src/sync/sync-operation.js.map +1 -0
- package/dist/src/sync/types.d.ts +61 -0
- package/dist/src/sync/types.d.ts.map +1 -0
- package/dist/src/sync/types.js +16 -0
- package/dist/src/sync/types.js.map +1 -0
- package/dist/src/sync/utils.d.ts +17 -0
- package/dist/src/sync/utils.d.ts.map +1 -0
- package/dist/src/sync/utils.js +34 -0
- package/dist/src/sync/utils.js.map +1 -0
- package/package.json +9 -5
- package/dist/src/cache/types.d.ts.map +0 -1
- package/dist/src/cache/types.js.map +0 -1
- /package/dist/src/{cache → storage/migrations}/types.js +0 -0
|
@@ -1,25 +1,43 @@
|
|
|
1
|
+
import { OperationEventTypes, } from "../events/types.js";
|
|
1
2
|
import { JobStatus } from "./types.js";
|
|
2
3
|
/**
|
|
3
|
-
*
|
|
4
|
-
*
|
|
4
|
+
* Checks if a job status is terminal (job has finished).
|
|
5
|
+
* WRITE_COMPLETED is not terminal - it's an intermediate state.
|
|
6
|
+
* Only READ_MODELS_READY and FAILED are truly terminal.
|
|
7
|
+
*/
|
|
8
|
+
function isTerminalStatus(status) {
|
|
9
|
+
return status === JobStatus.READ_MODELS_READY || status === JobStatus.FAILED;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Event-driven implementation of IJobAwaiter.
|
|
13
|
+
* Subscribes to operation events to detect job completion without polling.
|
|
5
14
|
*/
|
|
6
15
|
export class JobAwaiter {
|
|
16
|
+
eventBus;
|
|
7
17
|
getJobStatus;
|
|
8
|
-
pollIntervalMs;
|
|
9
|
-
// Map from job ID to list of waiters (multiple waiters can wait for same job)
|
|
10
18
|
pendingJobs = new Map();
|
|
11
|
-
|
|
12
|
-
constructor(
|
|
19
|
+
unsubscribers = [];
|
|
20
|
+
constructor(eventBus, getJobStatus) {
|
|
21
|
+
this.eventBus = eventBus;
|
|
13
22
|
this.getJobStatus = getJobStatus;
|
|
14
|
-
this.
|
|
15
|
-
|
|
23
|
+
this.subscribeToEvents();
|
|
24
|
+
}
|
|
25
|
+
subscribeToEvents() {
|
|
26
|
+
this.unsubscribers.push(this.eventBus.subscribe(OperationEventTypes.OPERATION_WRITTEN, async (_type, event) => {
|
|
27
|
+
await this.handleOperationWritten(event);
|
|
28
|
+
}));
|
|
29
|
+
this.unsubscribers.push(this.eventBus.subscribe(OperationEventTypes.OPERATIONS_READY, async (_type, event) => {
|
|
30
|
+
await this.handleOperationsReady(event);
|
|
31
|
+
}));
|
|
32
|
+
this.unsubscribers.push(this.eventBus.subscribe(OperationEventTypes.JOB_FAILED, async (_type, event) => {
|
|
33
|
+
await this.handleJobFailed(event);
|
|
34
|
+
}));
|
|
16
35
|
}
|
|
17
36
|
shutdown() {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
this.intervalId = null;
|
|
37
|
+
for (const unsubscribe of this.unsubscribers) {
|
|
38
|
+
unsubscribe();
|
|
21
39
|
}
|
|
22
|
-
|
|
40
|
+
this.unsubscribers = [];
|
|
23
41
|
for (const [, waiters] of this.pendingJobs) {
|
|
24
42
|
for (const waiter of waiters) {
|
|
25
43
|
waiter.reject(new Error("JobAwaiter destroyed"));
|
|
@@ -28,21 +46,20 @@ export class JobAwaiter {
|
|
|
28
46
|
this.pendingJobs.clear();
|
|
29
47
|
}
|
|
30
48
|
async waitForJob(jobId, signal) {
|
|
31
|
-
// Check if signal is already aborted
|
|
32
49
|
if (signal?.aborted) {
|
|
33
50
|
throw new Error("Operation aborted");
|
|
34
51
|
}
|
|
35
|
-
|
|
52
|
+
const currentStatus = await this.getJobStatus(jobId, signal);
|
|
53
|
+
if (isTerminalStatus(currentStatus.status)) {
|
|
54
|
+
return currentStatus;
|
|
55
|
+
}
|
|
36
56
|
const promise = new Promise((resolve, reject) => {
|
|
37
57
|
const waiter = { resolve, reject, signal };
|
|
38
|
-
// Add to the list of waiters for this job
|
|
39
58
|
const existingWaiters = this.pendingJobs.get(jobId) || [];
|
|
40
59
|
existingWaiters.push(waiter);
|
|
41
60
|
this.pendingJobs.set(jobId, existingWaiters);
|
|
42
|
-
// If signal is provided, handle abort
|
|
43
61
|
if (signal) {
|
|
44
62
|
const abortHandler = () => {
|
|
45
|
-
// Find and remove this specific waiter
|
|
46
63
|
const waiters = this.pendingJobs.get(jobId);
|
|
47
64
|
if (waiters) {
|
|
48
65
|
const index = waiters.indexOf(waiter);
|
|
@@ -52,81 +69,55 @@ export class JobAwaiter {
|
|
|
52
69
|
this.pendingJobs.delete(jobId);
|
|
53
70
|
}
|
|
54
71
|
waiter.reject(new Error("Operation aborted"));
|
|
55
|
-
this.stopIntervalIfNoJobs();
|
|
56
72
|
}
|
|
57
73
|
}
|
|
58
74
|
};
|
|
59
75
|
signal.addEventListener("abort", abortHandler, { once: true });
|
|
60
76
|
}
|
|
61
77
|
});
|
|
62
|
-
// Start interval if not already running
|
|
63
|
-
this.startInterval();
|
|
64
78
|
return promise;
|
|
65
79
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
void this.checkPendingJobs();
|
|
70
|
-
}, this.pollIntervalMs);
|
|
71
|
-
// Check immediately as well - schedule it for next tick
|
|
72
|
-
setTimeout(() => void this.checkPendingJobs(), 0);
|
|
73
|
-
}
|
|
80
|
+
async handleOperationWritten(event) {
|
|
81
|
+
const jobId = event.jobId;
|
|
82
|
+
await this.checkAndResolveWaiters(jobId);
|
|
74
83
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
84
|
+
async handleOperationsReady(event) {
|
|
85
|
+
const jobId = event.jobId;
|
|
86
|
+
await this.checkAndResolveWaiters(jobId);
|
|
87
|
+
}
|
|
88
|
+
async handleJobFailed(event) {
|
|
89
|
+
await this.checkAndResolveWaiters(event.jobId);
|
|
80
90
|
}
|
|
81
|
-
async
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
91
|
+
async checkAndResolveWaiters(jobId) {
|
|
92
|
+
const waiters = this.pendingJobs.get(jobId);
|
|
93
|
+
if (!waiters || waiters.length === 0) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
try {
|
|
97
|
+
const activeWaiters = waiters.filter((w) => !w.signal?.aborted);
|
|
98
|
+
if (activeWaiters.length === 0) {
|
|
99
|
+
this.pendingJobs.delete(jobId);
|
|
88
100
|
return;
|
|
89
101
|
}
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
this.pendingJobs.delete(jobId);
|
|
96
|
-
return;
|
|
102
|
+
const jobInfo = await this.getJobStatus(jobId, activeWaiters[0].signal);
|
|
103
|
+
if (isTerminalStatus(jobInfo.status)) {
|
|
104
|
+
this.pendingJobs.delete(jobId);
|
|
105
|
+
for (const waiter of activeWaiters) {
|
|
106
|
+
waiter.resolve(jobInfo);
|
|
97
107
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
if (jobInfo.status === JobStatus.COMPLETED ||
|
|
102
|
-
jobInfo.status === JobStatus.FAILED) {
|
|
103
|
-
// Remove from pending
|
|
104
|
-
this.pendingJobs.delete(jobId);
|
|
105
|
-
// Resolve all active waiters
|
|
106
|
-
for (const waiter of activeWaiters) {
|
|
107
|
-
waiter.resolve(jobInfo);
|
|
108
|
-
}
|
|
109
|
-
// Reject aborted waiters
|
|
110
|
-
for (const waiter of waiters) {
|
|
111
|
-
if (waiter.signal?.aborted) {
|
|
112
|
-
waiter.reject(new Error("Operation aborted"));
|
|
113
|
-
}
|
|
108
|
+
for (const waiter of waiters) {
|
|
109
|
+
if (waiter.signal?.aborted) {
|
|
110
|
+
waiter.reject(new Error("Operation aborted"));
|
|
114
111
|
}
|
|
115
112
|
}
|
|
116
113
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
waiter.reject(error instanceof Error ? error : new Error(String(error)));
|
|
123
|
-
}
|
|
114
|
+
}
|
|
115
|
+
catch (error) {
|
|
116
|
+
this.pendingJobs.delete(jobId);
|
|
117
|
+
for (const waiter of waiters) {
|
|
118
|
+
waiter.reject(error instanceof Error ? error : new Error(String(error)));
|
|
124
119
|
}
|
|
125
|
-
}
|
|
126
|
-
// Wait for all checks to complete
|
|
127
|
-
await Promise.all(jobChecks);
|
|
128
|
-
// Stop interval if no more jobs
|
|
129
|
-
this.stopIntervalIfNoJobs();
|
|
120
|
+
}
|
|
130
121
|
}
|
|
131
122
|
}
|
|
132
123
|
//# sourceMappingURL=awaiter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"awaiter.js","sourceRoot":"","sources":["../../../src/shared/awaiter.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"awaiter.js","sourceRoot":"","sources":["../../../src/shared/awaiter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { ConsistencyCoordinate, ConsistencyKey } from "./types.js";
|
|
2
|
+
export interface IConsistencyTracker {
|
|
3
|
+
/**
|
|
4
|
+
* Updates the tracker with new operation indexes.
|
|
5
|
+
* When multiple coordinates have the same key, keeps the highest operationIndex.
|
|
6
|
+
* Resolves any pending waiters whose coordinates are now satisfied.
|
|
7
|
+
*/
|
|
8
|
+
update(coordinates: ConsistencyCoordinate[]): void;
|
|
9
|
+
/**
|
|
10
|
+
* Returns the latest operation index for a given key, or undefined if not tracked.
|
|
11
|
+
*/
|
|
12
|
+
getLatest(key: ConsistencyKey): number | undefined;
|
|
13
|
+
/**
|
|
14
|
+
* Returns a promise that resolves when all coordinates are satisfied.
|
|
15
|
+
* Rejects if the timeout is reached or the signal is aborted.
|
|
16
|
+
*/
|
|
17
|
+
waitFor(coordinates: ConsistencyCoordinate[], timeoutMs?: number, signal?: AbortSignal): Promise<void>;
|
|
18
|
+
/**
|
|
19
|
+
* Returns a serializable snapshot of the current state.
|
|
20
|
+
*/
|
|
21
|
+
serialize(): Array<[ConsistencyKey, number]>;
|
|
22
|
+
/**
|
|
23
|
+
* Restores state from a serialized snapshot.
|
|
24
|
+
*/
|
|
25
|
+
hydrate(entries: Array<[ConsistencyKey, number]>): void;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Creates a consistency key from documentId, scope, and branch.
|
|
29
|
+
*/
|
|
30
|
+
export declare function makeConsistencyKey(documentId: string, scope: string, branch: string): ConsistencyKey;
|
|
31
|
+
/**
|
|
32
|
+
* Tracks operation indexes for documents and provides read-after-write consistency guarantees.
|
|
33
|
+
* Maintains an in-memory map of the latest operation index for each (documentId, scope, branch) tuple.
|
|
34
|
+
*/
|
|
35
|
+
export declare class ConsistencyTracker implements IConsistencyTracker {
|
|
36
|
+
private state;
|
|
37
|
+
private waiters;
|
|
38
|
+
update(coordinates: ConsistencyCoordinate[]): void;
|
|
39
|
+
getLatest(key: ConsistencyKey): number | undefined;
|
|
40
|
+
waitFor(coordinates: ConsistencyCoordinate[], timeoutMs?: number, signal?: AbortSignal): Promise<void>;
|
|
41
|
+
serialize(): Array<[ConsistencyKey, number]>;
|
|
42
|
+
hydrate(entries: Array<[ConsistencyKey, number]>): void;
|
|
43
|
+
private deduplicateCoordinates;
|
|
44
|
+
private areCoordinatesSatisfied;
|
|
45
|
+
private checkWaiters;
|
|
46
|
+
private removeWaiter;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=consistency-tracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consistency-tracker.d.ts","sourceRoot":"","sources":["../../../src/shared/consistency-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAExE,MAAM,WAAW,mBAAmB;IAClC;;;;OAIG;IACH,MAAM,CAAC,WAAW,EAAE,qBAAqB,EAAE,GAAG,IAAI,CAAC;IAEnD;;OAEG;IACH,SAAS,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,GAAG,SAAS,CAAC;IAEnD;;;OAGG;IACH,OAAO,CACL,WAAW,EAAE,qBAAqB,EAAE,EACpC,SAAS,CAAC,EAAE,MAAM,EAClB,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjB;;OAEG;IACH,SAAS,IAAI,KAAK,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,CAAC;IAE7C;;OAEG;IACH,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC;CACzD;AAUD;;GAEG;AACH,wBAAgB,kBAAkB,CAChC,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,GACb,cAAc,CAEhB;AAED;;;GAGG;AACH,qBAAa,kBAAmB,YAAW,mBAAmB;IAC5D,OAAO,CAAC,KAAK,CAAqC;IAClD,OAAO,CAAC,OAAO,CAAgB;IAE/B,MAAM,CAAC,WAAW,EAAE,qBAAqB,EAAE,GAAG,IAAI;IAmBlD,SAAS,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,GAAG,SAAS;IAIlD,OAAO,CACL,WAAW,EAAE,qBAAqB,EAAE,EACpC,SAAS,CAAC,EAAE,MAAM,EAClB,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC;IAoChB,SAAS,IAAI,KAAK,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;IAI5C,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,GAAG,IAAI;IAOvD,OAAO,CAAC,sBAAsB;IAsB9B,OAAO,CAAC,uBAAuB;IAkB/B,OAAO,CAAC,YAAY;IA0BpB,OAAO,CAAC,YAAY;CASrB"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Creates a consistency key from documentId, scope, and branch.
|
|
3
|
+
*/
|
|
4
|
+
export function makeConsistencyKey(documentId, scope, branch) {
|
|
5
|
+
return `${documentId}:${scope}:${branch}`;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Tracks operation indexes for documents and provides read-after-write consistency guarantees.
|
|
9
|
+
* Maintains an in-memory map of the latest operation index for each (documentId, scope, branch) tuple.
|
|
10
|
+
*/
|
|
11
|
+
export class ConsistencyTracker {
|
|
12
|
+
state = new Map();
|
|
13
|
+
waiters = [];
|
|
14
|
+
update(coordinates) {
|
|
15
|
+
const deduplicated = this.deduplicateCoordinates(coordinates);
|
|
16
|
+
for (let i = 0; i < deduplicated.length; i++) {
|
|
17
|
+
const coord = deduplicated[i];
|
|
18
|
+
const key = makeConsistencyKey(coord.documentId, coord.scope, coord.branch);
|
|
19
|
+
const current = this.state.get(key);
|
|
20
|
+
if (current === undefined || coord.operationIndex > current) {
|
|
21
|
+
this.state.set(key, coord.operationIndex);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
this.checkWaiters();
|
|
25
|
+
}
|
|
26
|
+
getLatest(key) {
|
|
27
|
+
return this.state.get(key);
|
|
28
|
+
}
|
|
29
|
+
waitFor(coordinates, timeoutMs, signal) {
|
|
30
|
+
if (signal?.aborted) {
|
|
31
|
+
return Promise.reject(new Error("Operation aborted"));
|
|
32
|
+
}
|
|
33
|
+
if (this.areCoordinatesSatisfied(coordinates)) {
|
|
34
|
+
return Promise.resolve();
|
|
35
|
+
}
|
|
36
|
+
return new Promise((resolve, reject) => {
|
|
37
|
+
const waiter = {
|
|
38
|
+
coordinates,
|
|
39
|
+
resolve,
|
|
40
|
+
reject,
|
|
41
|
+
signal,
|
|
42
|
+
};
|
|
43
|
+
if (timeoutMs !== undefined) {
|
|
44
|
+
waiter.timeoutId = setTimeout(() => {
|
|
45
|
+
this.removeWaiter(waiter);
|
|
46
|
+
reject(new Error(`Consistency wait timed out after ${timeoutMs}ms`));
|
|
47
|
+
}, timeoutMs);
|
|
48
|
+
}
|
|
49
|
+
if (signal) {
|
|
50
|
+
const abortHandler = () => {
|
|
51
|
+
this.removeWaiter(waiter);
|
|
52
|
+
reject(new Error("Operation aborted"));
|
|
53
|
+
};
|
|
54
|
+
signal.addEventListener("abort", abortHandler, { once: true });
|
|
55
|
+
}
|
|
56
|
+
this.waiters.push(waiter);
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
serialize() {
|
|
60
|
+
return Array.from(this.state.entries());
|
|
61
|
+
}
|
|
62
|
+
hydrate(entries) {
|
|
63
|
+
this.state.clear();
|
|
64
|
+
for (const [key, index] of entries) {
|
|
65
|
+
this.state.set(key, index);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
deduplicateCoordinates(coordinates) {
|
|
69
|
+
const map = new Map();
|
|
70
|
+
for (let i = 0; i < coordinates.length; i++) {
|
|
71
|
+
const coord = coordinates[i];
|
|
72
|
+
const key = makeConsistencyKey(coord.documentId, coord.scope, coord.branch);
|
|
73
|
+
const existing = map.get(key);
|
|
74
|
+
if (!existing || coord.operationIndex > existing.operationIndex) {
|
|
75
|
+
map.set(key, coord);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return Array.from(map.values());
|
|
79
|
+
}
|
|
80
|
+
areCoordinatesSatisfied(coordinates) {
|
|
81
|
+
for (let i = 0; i < coordinates.length; i++) {
|
|
82
|
+
const coord = coordinates[i];
|
|
83
|
+
const key = makeConsistencyKey(coord.documentId, coord.scope, coord.branch);
|
|
84
|
+
const latest = this.state.get(key);
|
|
85
|
+
if (latest === undefined || latest < coord.operationIndex) {
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
checkWaiters() {
|
|
92
|
+
const satisfiedWaiters = [];
|
|
93
|
+
const unsatisfiedWaiters = [];
|
|
94
|
+
for (const waiter of this.waiters) {
|
|
95
|
+
if (waiter.signal?.aborted) {
|
|
96
|
+
continue;
|
|
97
|
+
}
|
|
98
|
+
if (this.areCoordinatesSatisfied(waiter.coordinates)) {
|
|
99
|
+
satisfiedWaiters.push(waiter);
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
unsatisfiedWaiters.push(waiter);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
this.waiters = unsatisfiedWaiters;
|
|
106
|
+
for (const waiter of satisfiedWaiters) {
|
|
107
|
+
if (waiter.timeoutId !== undefined) {
|
|
108
|
+
clearTimeout(waiter.timeoutId);
|
|
109
|
+
}
|
|
110
|
+
waiter.resolve();
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
removeWaiter(waiter) {
|
|
114
|
+
const index = this.waiters.indexOf(waiter);
|
|
115
|
+
if (index !== -1) {
|
|
116
|
+
this.waiters.splice(index, 1);
|
|
117
|
+
}
|
|
118
|
+
if (waiter.timeoutId !== undefined) {
|
|
119
|
+
clearTimeout(waiter.timeoutId);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=consistency-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consistency-tracker.js","sourceRoot":"","sources":["../../../src/shared/consistency-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -50,6 +50,10 @@ export type JobInfo = {
|
|
|
50
50
|
error?: ErrorInfo;
|
|
51
51
|
errorHistory?: ErrorInfo[];
|
|
52
52
|
result?: any;
|
|
53
|
+
/**
|
|
54
|
+
* A token for coordinating reads, only valid once a job reaches COMPLETED.
|
|
55
|
+
*/
|
|
56
|
+
consistencyToken: ConsistencyToken;
|
|
53
57
|
};
|
|
54
58
|
/**
|
|
55
59
|
* Job execution statuses
|
|
@@ -59,8 +63,10 @@ export declare enum JobStatus {
|
|
|
59
63
|
PENDING = "PENDING",
|
|
60
64
|
/** Job is currently being executed */
|
|
61
65
|
RUNNING = "RUNNING",
|
|
62
|
-
/**
|
|
63
|
-
|
|
66
|
+
/** Operations have been written to the operation store (OPERATION_WRITTEN event) */
|
|
67
|
+
WRITE_COMPLETED = "WRITE_COMPLETED",
|
|
68
|
+
/** Read models have finished indexing operations (OPERATIONS_READY event) */
|
|
69
|
+
READ_MODELS_READY = "READ_MODELS_READY",
|
|
64
70
|
/** Job failed (may be retried) */
|
|
65
71
|
FAILED = "FAILED"
|
|
66
72
|
}
|
|
@@ -100,4 +106,26 @@ export type PagedResults<T> = {
|
|
|
100
106
|
next?: () => Promise<PagedResults<T>>;
|
|
101
107
|
nextCursor?: string;
|
|
102
108
|
};
|
|
109
|
+
/**
|
|
110
|
+
* A string key in the format `documentId:scope:branch` used to identify a consistency checkpoint.
|
|
111
|
+
*/
|
|
112
|
+
export type ConsistencyKey = `${string}:${string}:${string}`;
|
|
113
|
+
/**
|
|
114
|
+
* Describes a specific point in a document's operation history.
|
|
115
|
+
*/
|
|
116
|
+
export type ConsistencyCoordinate = {
|
|
117
|
+
documentId: string;
|
|
118
|
+
scope: string;
|
|
119
|
+
branch: string;
|
|
120
|
+
operationIndex: number;
|
|
121
|
+
};
|
|
122
|
+
/**
|
|
123
|
+
* A token that captures the state of write operations at a point in time.
|
|
124
|
+
* Can be used to ensure read-after-write consistency.
|
|
125
|
+
*/
|
|
126
|
+
export type ConsistencyToken = {
|
|
127
|
+
version: 1;
|
|
128
|
+
createdAtUtcIso: string;
|
|
129
|
+
coordinates: ConsistencyCoordinate[];
|
|
130
|
+
};
|
|
103
131
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/shared/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,eAAO,MAAM,kBAAkB,yCAAyC,CAAC;AAEzE;;GAEG;AACH,MAAM,MAAM,SAAS,GAAG;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG;IAC3B;;;;;;;;OAQG;IACH,IAAI,UAAU,IAAI,OAAO,CAAC;CAC3B,CAAC;AAEF;;GAEG;AACH,oBAAY,eAAe;IACzB,IAAI,SAAS;IACb,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,oBAAY,sBAAsB;IAChC,KAAK,UAAU;IACf,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,SAAS,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,YAAY,CAAC,EAAE,SAAS,EAAE,CAAC;IAC3B,MAAM,CAAC,EAAE,GAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/shared/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,eAAO,MAAM,kBAAkB,yCAAyC,CAAC;AAEzE;;GAEG;AACH,MAAM,MAAM,SAAS,GAAG;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG;IAC3B;;;;;;;;OAQG;IACH,IAAI,UAAU,IAAI,OAAO,CAAC;CAC3B,CAAC;AAEF;;GAEG;AACH,oBAAY,eAAe;IACzB,IAAI,SAAS;IACb,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,oBAAY,sBAAsB;IAChC,KAAK,UAAU;IACf,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,SAAS,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,YAAY,CAAC,EAAE,SAAS,EAAE,CAAC;IAC3B,MAAM,CAAC,EAAE,GAAG,CAAC;IAEb;;OAEG;IACH,gBAAgB,EAAE,gBAAgB,CAAC;CACpC,CAAC;AAEF;;GAEG;AACH,oBAAY,SAAS;IACnB,wCAAwC;IACxC,OAAO,YAAY;IACnB,sCAAsC;IACtC,OAAO,YAAY;IACnB,oFAAoF;IACpF,eAAe,oBAAoB;IACnC,6EAA6E;IAC7E,iBAAiB,sBAAsB;IACvC,kCAAkC;IAClC,MAAM,WAAW;CAClB;AAED;;;GAGG;AACH,MAAM,MAAM,UAAU,GAAG;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF;;;;GAIG;AACH,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;CAClB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,YAAY,CAAC,CAAC,IAAI;IAC5B,OAAO,EAAE,CAAC,EAAE,CAAC;IACb,OAAO,EAAE,aAAa,CAAC;IAEvB,IAAI,CAAC,EAAE,MAAM,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,GAAG,MAAM,IAAI,MAAM,IAAI,MAAM,EAAE,CAAC;AAE7D;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAAG;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,gBAAgB,GAAG;IAC7B,OAAO,EAAE,CAAC,CAAC;IACX,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,qBAAqB,EAAE,CAAC;CACtC,CAAC"}
|
package/dist/src/shared/types.js
CHANGED
|
@@ -28,8 +28,10 @@ export var JobStatus;
|
|
|
28
28
|
JobStatus["PENDING"] = "PENDING";
|
|
29
29
|
/** Job is currently being executed */
|
|
30
30
|
JobStatus["RUNNING"] = "RUNNING";
|
|
31
|
-
/**
|
|
32
|
-
JobStatus["
|
|
31
|
+
/** Operations have been written to the operation store (OPERATION_WRITTEN event) */
|
|
32
|
+
JobStatus["WRITE_COMPLETED"] = "WRITE_COMPLETED";
|
|
33
|
+
/** Read models have finished indexing operations (OPERATIONS_READY event) */
|
|
34
|
+
JobStatus["READ_MODELS_READY"] = "READ_MODELS_READY";
|
|
33
35
|
/** Job failed (may be retried) */
|
|
34
36
|
JobStatus["FAILED"] = "FAILED";
|
|
35
37
|
})(JobStatus || (JobStatus = {}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/shared/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AA0BzE;;GAEG;AACH,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,gCAAa,CAAA;IACb,sCAAmB,CAAA;AACrB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,yCAAe,CAAA;IACf,6CAAmB,CAAA;AACrB,CAAC,EAHW,sBAAsB,KAAtB,sBAAsB,QAGjC;
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/shared/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AA0BzE;;GAEG;AACH,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,gCAAa,CAAA;IACb,sCAAmB,CAAA;AACrB,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AAED;;GAEG;AACH,MAAM,CAAN,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAChC,yCAAe,CAAA;IACf,6CAAmB,CAAA;AACrB,CAAC,EAHW,sBAAsB,KAAtB,sBAAsB,QAGjC;AAoBD;;GAEG;AACH,MAAM,CAAN,IAAY,SAWX;AAXD,WAAY,SAAS;IACnB,wCAAwC;IACxC,gCAAmB,CAAA;IACnB,sCAAsC;IACtC,gCAAmB,CAAA;IACnB,oFAAoF;IACpF,gDAAmC,CAAA;IACnC,6EAA6E;IAC7E,oDAAuC,CAAA;IACvC,kCAAkC;IAClC,8BAAiB,CAAA;AACnB,CAAC,EAXW,SAAS,KAAT,SAAS,QAWpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/storage/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/storage/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC"}
|