@powerhousedao/reactor 6.0.0-dev.69 → 6.0.0-dev.77
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/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +19998 -62
- package/dist/src/sync/index.d.ts +1 -1
- package/dist/src/sync/index.d.ts.map +1 -1
- package/dist/src/sync/sync-manager.d.ts.map +1 -1
- package/dist/src/sync/types.d.ts +11 -0
- package/dist/src/sync/types.d.ts.map +1 -1
- package/package.json +17 -10
- package/dist/src/actions/index.js +0 -76
- package/dist/src/actions/index.js.map +0 -1
- package/dist/src/cache/buffer/ring-buffer.js +0 -69
- package/dist/src/cache/buffer/ring-buffer.js.map +0 -1
- package/dist/src/cache/collection-membership-cache.js +0 -33
- package/dist/src/cache/collection-membership-cache.js.map +0 -1
- package/dist/src/cache/document-meta-cache-types.js +0 -2
- package/dist/src/cache/document-meta-cache-types.js.map +0 -1
- package/dist/src/cache/document-meta-cache.js +0 -129
- package/dist/src/cache/document-meta-cache.js.map +0 -1
- package/dist/src/cache/index.js +0 -2
- package/dist/src/cache/index.js.map +0 -1
- package/dist/src/cache/kysely-operation-index.js +0 -345
- package/dist/src/cache/kysely-operation-index.js.map +0 -1
- package/dist/src/cache/kysely-write-cache.js +0 -411
- package/dist/src/cache/kysely-write-cache.js.map +0 -1
- package/dist/src/cache/lru/lru-tracker.js +0 -96
- package/dist/src/cache/lru/lru-tracker.js.map +0 -1
- package/dist/src/cache/operation-index-types.js +0 -4
- package/dist/src/cache/operation-index-types.js.map +0 -1
- package/dist/src/cache/write/interfaces.js +0 -2
- package/dist/src/cache/write/interfaces.js.map +0 -1
- package/dist/src/cache/write-cache-types.js +0 -2
- package/dist/src/cache/write-cache-types.js.map +0 -1
- package/dist/src/client/reactor-client.js +0 -497
- package/dist/src/client/reactor-client.js.map +0 -1
- package/dist/src/client/types.js +0 -14
- package/dist/src/client/types.js.map +0 -1
- package/dist/src/core/reactor-builder.js +0 -306
- package/dist/src/core/reactor-builder.js.map +0 -1
- package/dist/src/core/reactor-client-builder.js +0 -132
- package/dist/src/core/reactor-client-builder.js.map +0 -1
- package/dist/src/core/reactor.js +0 -640
- package/dist/src/core/reactor.js.map +0 -1
- package/dist/src/core/types.js +0 -2
- package/dist/src/core/types.js.map +0 -1
- package/dist/src/core/utils.js +0 -225
- package/dist/src/core/utils.js.map +0 -1
- package/dist/src/events/event-bus.js +0 -53
- package/dist/src/events/event-bus.js.map +0 -1
- package/dist/src/events/interfaces.js +0 -2
- package/dist/src/events/interfaces.js.map +0 -1
- package/dist/src/events/types.js +0 -30
- package/dist/src/events/types.js.map +0 -1
- package/dist/src/executor/document-action-handler.js +0 -356
- package/dist/src/executor/document-action-handler.js.map +0 -1
- package/dist/src/executor/interfaces.js +0 -2
- package/dist/src/executor/interfaces.js.map +0 -1
- package/dist/src/executor/signature-verifier.js +0 -70
- package/dist/src/executor/signature-verifier.js.map +0 -1
- package/dist/src/executor/simple-job-executor-manager.js +0 -345
- package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
- package/dist/src/executor/simple-job-executor.js +0 -423
- package/dist/src/executor/simple-job-executor.js.map +0 -1
- package/dist/src/executor/types.js +0 -11
- package/dist/src/executor/types.js.map +0 -1
- package/dist/src/executor/util.js +0 -230
- package/dist/src/executor/util.js.map +0 -1
- package/dist/src/index.js.map +0 -1
- package/dist/src/job-tracker/in-memory-job-tracker.js +0 -114
- package/dist/src/job-tracker/in-memory-job-tracker.js.map +0 -1
- package/dist/src/job-tracker/index.js +0 -2
- package/dist/src/job-tracker/index.js.map +0 -1
- package/dist/src/job-tracker/interfaces.js +0 -2
- package/dist/src/job-tracker/interfaces.js.map +0 -1
- package/dist/src/logging/console.js +0 -2
- package/dist/src/logging/console.js.map +0 -1
- package/dist/src/logging/types.js +0 -2
- package/dist/src/logging/types.js.map +0 -1
- package/dist/src/processors/index.js +0 -2
- package/dist/src/processors/index.js.map +0 -1
- package/dist/src/processors/processor-manager.js +0 -165
- package/dist/src/processors/processor-manager.js.map +0 -1
- package/dist/src/processors/relational/types.js +0 -2
- package/dist/src/processors/relational/types.js.map +0 -1
- package/dist/src/processors/relational/utils.js +0 -2
- package/dist/src/processors/relational/utils.js.map +0 -1
- package/dist/src/processors/utils.js +0 -59
- package/dist/src/processors/utils.js.map +0 -1
- package/dist/src/queue/interfaces.js +0 -2
- package/dist/src/queue/interfaces.js.map +0 -1
- package/dist/src/queue/job-execution-handle.js +0 -71
- package/dist/src/queue/job-execution-handle.js.map +0 -1
- package/dist/src/queue/queue.js +0 -493
- package/dist/src/queue/queue.js.map +0 -1
- package/dist/src/queue/types.js +0 -19
- package/dist/src/queue/types.js.map +0 -1
- package/dist/src/read-models/base-read-model.js +0 -143
- package/dist/src/read-models/base-read-model.js.map +0 -1
- package/dist/src/read-models/coordinator.js +0 -72
- package/dist/src/read-models/coordinator.js.map +0 -1
- package/dist/src/read-models/document-view.js +0 -457
- package/dist/src/read-models/document-view.js.map +0 -1
- package/dist/src/read-models/interfaces.js +0 -2
- package/dist/src/read-models/interfaces.js.map +0 -1
- package/dist/src/read-models/types.js +0 -2
- package/dist/src/read-models/types.js.map +0 -1
- package/dist/src/registry/document-model-resolver.js +0 -81
- package/dist/src/registry/document-model-resolver.js.map +0 -1
- package/dist/src/registry/implementation.js +0 -226
- package/dist/src/registry/implementation.js.map +0 -1
- package/dist/src/registry/index.js +0 -3
- package/dist/src/registry/index.js.map +0 -1
- package/dist/src/registry/interfaces.js +0 -2
- package/dist/src/registry/interfaces.js.map +0 -1
- package/dist/src/shared/awaiter.js +0 -123
- package/dist/src/shared/awaiter.js.map +0 -1
- package/dist/src/shared/collect-all-pages.js +0 -17
- package/dist/src/shared/collect-all-pages.js.map +0 -1
- package/dist/src/shared/consistency-tracker.js +0 -123
- package/dist/src/shared/consistency-tracker.js.map +0 -1
- package/dist/src/shared/drive-url.js +0 -17
- package/dist/src/shared/drive-url.js.map +0 -1
- package/dist/src/shared/errors.js +0 -93
- package/dist/src/shared/errors.js.map +0 -1
- package/dist/src/shared/factories.js +0 -41
- package/dist/src/shared/factories.js.map +0 -1
- package/dist/src/shared/types.js +0 -38
- package/dist/src/shared/types.js.map +0 -1
- package/dist/src/shared/utils.js +0 -8
- package/dist/src/shared/utils.js.map +0 -1
- package/dist/src/signer/passthrough-signer.js +0 -17
- package/dist/src/signer/passthrough-signer.js.map +0 -1
- package/dist/src/signer/types.js +0 -2
- package/dist/src/signer/types.js.map +0 -1
- package/dist/src/storage/index.js +0 -3
- package/dist/src/storage/index.js.map +0 -1
- package/dist/src/storage/interfaces.js +0 -29
- package/dist/src/storage/interfaces.js.map +0 -1
- package/dist/src/storage/kysely/document-indexer.js +0 -421
- package/dist/src/storage/kysely/document-indexer.js.map +0 -1
- package/dist/src/storage/kysely/keyframe-store.js +0 -64
- package/dist/src/storage/kysely/keyframe-store.js.map +0 -1
- package/dist/src/storage/kysely/store.js +0 -264
- package/dist/src/storage/kysely/store.js.map +0 -1
- package/dist/src/storage/kysely/sync-cursor-storage.js +0 -97
- package/dist/src/storage/kysely/sync-cursor-storage.js.map +0 -1
- package/dist/src/storage/kysely/sync-dead-letter-storage.js +0 -110
- package/dist/src/storage/kysely/sync-dead-letter-storage.js.map +0 -1
- package/dist/src/storage/kysely/sync-remote-storage.js +0 -133
- package/dist/src/storage/kysely/sync-remote-storage.js.map +0 -1
- package/dist/src/storage/kysely/types.js +0 -2
- package/dist/src/storage/kysely/types.js.map +0 -1
- package/dist/src/storage/migrations/001_create_operation_table.js +0 -41
- package/dist/src/storage/migrations/001_create_operation_table.js.map +0 -1
- package/dist/src/storage/migrations/002_create_keyframe_table.js +0 -27
- package/dist/src/storage/migrations/002_create_keyframe_table.js.map +0 -1
- package/dist/src/storage/migrations/003_create_document_table.js +0 -10
- package/dist/src/storage/migrations/003_create_document_table.js.map +0 -1
- package/dist/src/storage/migrations/004_create_document_relationship_table.js +0 -35
- package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +0 -1
- package/dist/src/storage/migrations/005_create_indexer_state_table.js +0 -10
- package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +0 -1
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js +0 -49
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +0 -1
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js +0 -24
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +0 -1
- package/dist/src/storage/migrations/008_create_view_state_table.js +0 -10
- package/dist/src/storage/migrations/008_create_view_state_table.js.map +0 -1
- package/dist/src/storage/migrations/009_create_operation_index_tables.js +0 -50
- package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +0 -1
- package/dist/src/storage/migrations/010_create_sync_tables.js +0 -43
- package/dist/src/storage/migrations/010_create_sync_tables.js.map +0 -1
- package/dist/src/storage/migrations/011_add_cursor_type_column.js +0 -29
- package/dist/src/storage/migrations/011_add_cursor_type_column.js.map +0 -1
- package/dist/src/storage/migrations/012_add_source_remote_column.js +0 -7
- package/dist/src/storage/migrations/012_add_source_remote_column.js.map +0 -1
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js +0 -24
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js.map +0 -1
- package/dist/src/storage/migrations/index.js +0 -3
- package/dist/src/storage/migrations/index.js.map +0 -1
- package/dist/src/storage/migrations/migrator.js +0 -84
- package/dist/src/storage/migrations/migrator.js.map +0 -1
- package/dist/src/storage/migrations/run-migrations.js +0 -58
- package/dist/src/storage/migrations/run-migrations.js.map +0 -1
- package/dist/src/storage/migrations/types.js +0 -2
- package/dist/src/storage/migrations/types.js.map +0 -1
- package/dist/src/storage/txn.js +0 -42
- package/dist/src/storage/txn.js.map +0 -1
- package/dist/src/subs/default-error-handler.js +0 -27
- package/dist/src/subs/default-error-handler.js.map +0 -1
- package/dist/src/subs/react-subscription-manager.js +0 -185
- package/dist/src/subs/react-subscription-manager.js.map +0 -1
- package/dist/src/subs/subscription-notification-read-model.js +0 -62
- package/dist/src/subs/subscription-notification-read-model.js.map +0 -1
- package/dist/src/subs/types.js +0 -2
- package/dist/src/subs/types.js.map +0 -1
- package/dist/src/sync/batch-aggregator.js +0 -94
- package/dist/src/sync/batch-aggregator.js.map +0 -1
- package/dist/src/sync/buffered-mailbox.js +0 -164
- package/dist/src/sync/buffered-mailbox.js.map +0 -1
- package/dist/src/sync/channels/gql-req-channel.js +0 -548
- package/dist/src/sync/channels/gql-req-channel.js.map +0 -1
- package/dist/src/sync/channels/gql-request-channel-factory.js +0 -105
- package/dist/src/sync/channels/gql-request-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/gql-res-channel.js +0 -79
- package/dist/src/sync/channels/gql-res-channel.js.map +0 -1
- package/dist/src/sync/channels/gql-response-channel-factory.js +0 -14
- package/dist/src/sync/channels/gql-response-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/index.js +0 -8
- package/dist/src/sync/channels/index.js.map +0 -1
- package/dist/src/sync/channels/interval-poll-timer.js +0 -123
- package/dist/src/sync/channels/interval-poll-timer.js.map +0 -1
- package/dist/src/sync/channels/poll-timer.js +0 -2
- package/dist/src/sync/channels/poll-timer.js.map +0 -1
- package/dist/src/sync/channels/utils.js +0 -161
- package/dist/src/sync/channels/utils.js.map +0 -1
- package/dist/src/sync/errors.js +0 -17
- package/dist/src/sync/errors.js.map +0 -1
- package/dist/src/sync/index.js +0 -11
- package/dist/src/sync/index.js.map +0 -1
- package/dist/src/sync/interfaces.js +0 -2
- package/dist/src/sync/interfaces.js.map +0 -1
- package/dist/src/sync/mailbox.js +0 -142
- package/dist/src/sync/mailbox.js.map +0 -1
- package/dist/src/sync/sync-awaiter.js +0 -124
- package/dist/src/sync/sync-awaiter.js.map +0 -1
- package/dist/src/sync/sync-builder.js +0 -52
- package/dist/src/sync/sync-builder.js.map +0 -1
- package/dist/src/sync/sync-manager.js +0 -447
- package/dist/src/sync/sync-manager.js.map +0 -1
- package/dist/src/sync/sync-operation.js +0 -70
- package/dist/src/sync/sync-operation.js.map +0 -1
- package/dist/src/sync/sync-status-tracker.js +0 -137
- package/dist/src/sync/sync-status-tracker.js.map +0 -1
- package/dist/src/sync/types.js +0 -31
- package/dist/src/sync/types.js.map +0 -1
- package/dist/src/sync/utils.js +0 -283
- package/dist/src/sync/utils.js.map +0 -1
- package/dist/src/utils/reshuffle.js +0 -91
- package/dist/src/utils/reshuffle.js.map +0 -1
|
@@ -1,345 +0,0 @@
|
|
|
1
|
-
import { ReactorEventTypes } from "../events/types.js";
|
|
2
|
-
import { QueueEventTypes } from "../queue/types.js";
|
|
3
|
-
import { ModuleNotFoundError } from "../registry/implementation.js";
|
|
4
|
-
import { DocumentDeletedError, DocumentNotFoundError, } from "../shared/errors.js";
|
|
5
|
-
/**
|
|
6
|
-
* Manages multiple job executors and coordinates job distribution.
|
|
7
|
-
* Listens for job available events and dispatches jobs to executors.
|
|
8
|
-
*/
|
|
9
|
-
export class SimpleJobExecutorManager {
|
|
10
|
-
executorFactory;
|
|
11
|
-
eventBus;
|
|
12
|
-
queue;
|
|
13
|
-
jobTracker;
|
|
14
|
-
logger;
|
|
15
|
-
resolver;
|
|
16
|
-
executors = [];
|
|
17
|
-
isRunning = false;
|
|
18
|
-
activeJobs = 0;
|
|
19
|
-
totalJobsProcessed = 0;
|
|
20
|
-
unsubscribe;
|
|
21
|
-
deferredJobs = new Map();
|
|
22
|
-
constructor(executorFactory, eventBus, queue, jobTracker, logger, resolver) {
|
|
23
|
-
this.executorFactory = executorFactory;
|
|
24
|
-
this.eventBus = eventBus;
|
|
25
|
-
this.queue = queue;
|
|
26
|
-
this.jobTracker = jobTracker;
|
|
27
|
-
this.logger = logger;
|
|
28
|
-
this.resolver = resolver;
|
|
29
|
-
}
|
|
30
|
-
async start(numExecutors) {
|
|
31
|
-
if (this.isRunning) {
|
|
32
|
-
throw new Error("JobExecutorManager is already running");
|
|
33
|
-
}
|
|
34
|
-
if (numExecutors < 1) {
|
|
35
|
-
throw new Error("Number of executors must be at least 1");
|
|
36
|
-
}
|
|
37
|
-
// Create executors
|
|
38
|
-
this.executors = [];
|
|
39
|
-
for (let i = 0; i < numExecutors; i++) {
|
|
40
|
-
this.executors.push(this.executorFactory());
|
|
41
|
-
}
|
|
42
|
-
// Start listening for job available events
|
|
43
|
-
this.unsubscribe = this.eventBus.subscribe(QueueEventTypes.JOB_AVAILABLE, async () => {
|
|
44
|
-
// Only process if we have capacity (simple round-robin for now)
|
|
45
|
-
if (this.activeJobs < this.executors.length) {
|
|
46
|
-
await this.processNextJob();
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
this.isRunning = true;
|
|
50
|
-
// Process any existing jobs in the queue
|
|
51
|
-
await this.processExistingJobs();
|
|
52
|
-
}
|
|
53
|
-
async stop(graceful = true) {
|
|
54
|
-
if (!this.isRunning) {
|
|
55
|
-
return;
|
|
56
|
-
}
|
|
57
|
-
// Stop listening for new jobs
|
|
58
|
-
if (this.unsubscribe) {
|
|
59
|
-
this.unsubscribe();
|
|
60
|
-
this.unsubscribe = undefined;
|
|
61
|
-
}
|
|
62
|
-
if (graceful) {
|
|
63
|
-
// Wait for active jobs to complete
|
|
64
|
-
while (this.activeJobs > 0) {
|
|
65
|
-
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
// Fail any deferred jobs that were never flushed
|
|
69
|
-
for (const [, jobs] of this.deferredJobs) {
|
|
70
|
-
for (const job of jobs) {
|
|
71
|
-
const errorInfo = this.toErrorInfo(new DocumentNotFoundError(job.documentId));
|
|
72
|
-
this.jobTracker.markFailed(job.id, errorInfo, job);
|
|
73
|
-
this.eventBus
|
|
74
|
-
.emit(ReactorEventTypes.JOB_FAILED, {
|
|
75
|
-
jobId: job.id,
|
|
76
|
-
error: new DocumentNotFoundError(job.documentId),
|
|
77
|
-
job,
|
|
78
|
-
})
|
|
79
|
-
.catch(() => { });
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
this.deferredJobs.clear();
|
|
83
|
-
this.executors = [];
|
|
84
|
-
this.isRunning = false;
|
|
85
|
-
}
|
|
86
|
-
getExecutors() {
|
|
87
|
-
return [...this.executors];
|
|
88
|
-
}
|
|
89
|
-
getStatus() {
|
|
90
|
-
return {
|
|
91
|
-
isRunning: this.isRunning,
|
|
92
|
-
numExecutors: this.executors.length,
|
|
93
|
-
activeJobs: this.activeJobs,
|
|
94
|
-
totalJobsProcessed: this.totalJobsProcessed,
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
|
-
async processNextJob() {
|
|
98
|
-
// dequeue next available job
|
|
99
|
-
let handle;
|
|
100
|
-
try {
|
|
101
|
-
handle = await this.queue.dequeueNext();
|
|
102
|
-
}
|
|
103
|
-
catch (error) {
|
|
104
|
-
this.logger.error("Error dequeueing next job: @Error", error);
|
|
105
|
-
return;
|
|
106
|
-
}
|
|
107
|
-
if (!handle) {
|
|
108
|
-
return;
|
|
109
|
-
}
|
|
110
|
-
// start the job execution
|
|
111
|
-
handle.start();
|
|
112
|
-
this.activeJobs++;
|
|
113
|
-
this.jobTracker.markRunning(handle.job.id);
|
|
114
|
-
// Emit JOB_RUNNING event
|
|
115
|
-
const runningEvent = {
|
|
116
|
-
jobId: handle.job.id,
|
|
117
|
-
jobMeta: handle.job.meta,
|
|
118
|
-
};
|
|
119
|
-
this.eventBus
|
|
120
|
-
.emit(ReactorEventTypes.JOB_RUNNING, runningEvent)
|
|
121
|
-
.catch(() => {
|
|
122
|
-
// Ignore event emission errors
|
|
123
|
-
});
|
|
124
|
-
// Find an available executor (simple round-robin)
|
|
125
|
-
const executorIndex = this.totalJobsProcessed % this.executors.length;
|
|
126
|
-
const executor = this.executors[executorIndex];
|
|
127
|
-
// execute the job
|
|
128
|
-
let result;
|
|
129
|
-
try {
|
|
130
|
-
result = await executor.executeJob(handle.job);
|
|
131
|
-
}
|
|
132
|
-
catch (error) {
|
|
133
|
-
const errorInfo = this.toErrorInfo(error instanceof Error ? error : String(error));
|
|
134
|
-
handle.fail(errorInfo);
|
|
135
|
-
this.activeJobs--;
|
|
136
|
-
this.jobTracker.markFailed(handle.job.id, errorInfo, handle.job);
|
|
137
|
-
this.eventBus
|
|
138
|
-
.emit(ReactorEventTypes.JOB_FAILED, {
|
|
139
|
-
jobId: handle.job.id,
|
|
140
|
-
error: new Error(errorInfo.message),
|
|
141
|
-
job: handle.job,
|
|
142
|
-
})
|
|
143
|
-
.catch(() => { });
|
|
144
|
-
await this.checkForMoreJobs();
|
|
145
|
-
return;
|
|
146
|
-
}
|
|
147
|
-
// handle the result
|
|
148
|
-
if (result.success) {
|
|
149
|
-
handle.complete();
|
|
150
|
-
this.totalJobsProcessed++;
|
|
151
|
-
if (this.hasCreateDocumentAction(handle.job)) {
|
|
152
|
-
await this.flushDeferredJobs(handle.job.documentId);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
else {
|
|
156
|
-
// Attempt model recovery before exhausting retries
|
|
157
|
-
if (result.error && ModuleNotFoundError.isError(result.error)) {
|
|
158
|
-
let modelLoaded = false;
|
|
159
|
-
try {
|
|
160
|
-
await this.resolver.ensureModelLoaded(result.error.documentType);
|
|
161
|
-
modelLoaded = true;
|
|
162
|
-
}
|
|
163
|
-
catch {
|
|
164
|
-
// Model could not be loaded, fall through to normal failure path
|
|
165
|
-
}
|
|
166
|
-
if (modelLoaded) {
|
|
167
|
-
const errorInfo = this.toErrorInfo(result.error);
|
|
168
|
-
try {
|
|
169
|
-
await this.queue.retryJob(handle.job.id, errorInfo);
|
|
170
|
-
this.activeJobs--;
|
|
171
|
-
await this.checkForMoreJobs();
|
|
172
|
-
return;
|
|
173
|
-
}
|
|
174
|
-
catch {
|
|
175
|
-
// Fall through to normal failure path
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
// DocumentNotFoundError: defer the job instead of failing immediately.
|
|
180
|
-
// A CREATE_DOCUMENT job may arrive later and unblock it.
|
|
181
|
-
if (result.error && DocumentNotFoundError.isError(result.error)) {
|
|
182
|
-
const job = handle.job;
|
|
183
|
-
handle.defer();
|
|
184
|
-
this.activeJobs--;
|
|
185
|
-
const docId = job.documentId;
|
|
186
|
-
const existing = this.deferredJobs.get(docId) ?? [];
|
|
187
|
-
existing.push(job);
|
|
188
|
-
this.deferredJobs.set(docId, existing);
|
|
189
|
-
await this.checkForMoreJobs();
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
if (result.error && DocumentDeletedError.isError(result.error)) {
|
|
193
|
-
const errorInfo = this.toErrorInfo(result.error);
|
|
194
|
-
this.jobTracker.markFailed(handle.job.id, errorInfo, handle.job);
|
|
195
|
-
this.eventBus
|
|
196
|
-
.emit(ReactorEventTypes.JOB_FAILED, {
|
|
197
|
-
jobId: handle.job.id,
|
|
198
|
-
error: result.error,
|
|
199
|
-
job: handle.job,
|
|
200
|
-
})
|
|
201
|
-
.catch(() => { });
|
|
202
|
-
handle.fail(errorInfo);
|
|
203
|
-
this.activeJobs--;
|
|
204
|
-
await this.checkForMoreJobs();
|
|
205
|
-
return;
|
|
206
|
-
}
|
|
207
|
-
// Handle retry logic
|
|
208
|
-
const retryCount = handle.job.retryCount || 0;
|
|
209
|
-
const maxRetries = handle.job.maxRetries || 0;
|
|
210
|
-
if (retryCount < maxRetries) {
|
|
211
|
-
const currentErrorInfo = result.error
|
|
212
|
-
? this.toErrorInfo(result.error)
|
|
213
|
-
: this.toErrorInfo("Unknown error");
|
|
214
|
-
try {
|
|
215
|
-
await this.queue.retryJob(handle.job.id, currentErrorInfo);
|
|
216
|
-
}
|
|
217
|
-
catch (error) {
|
|
218
|
-
const retryErrorInfo = this.toErrorInfo(error instanceof Error ? error : "Failed to retry job");
|
|
219
|
-
this.jobTracker.markFailed(handle.job.id, retryErrorInfo, handle.job);
|
|
220
|
-
this.eventBus
|
|
221
|
-
.emit(ReactorEventTypes.JOB_FAILED, {
|
|
222
|
-
jobId: handle.job.id,
|
|
223
|
-
error: result.error ?? new Error(retryErrorInfo.message),
|
|
224
|
-
job: handle.job,
|
|
225
|
-
})
|
|
226
|
-
.catch(() => { });
|
|
227
|
-
handle.fail(retryErrorInfo);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
else {
|
|
231
|
-
const currentErrorInfo = result.error
|
|
232
|
-
? this.toErrorInfo(result.error)
|
|
233
|
-
: this.toErrorInfo("Unknown error");
|
|
234
|
-
const fullErrorInfo = this.formatErrorHistory(handle.job.errorHistory, currentErrorInfo, retryCount + 1);
|
|
235
|
-
this.jobTracker.markFailed(handle.job.id, fullErrorInfo, handle.job);
|
|
236
|
-
this.eventBus
|
|
237
|
-
.emit(ReactorEventTypes.JOB_FAILED, {
|
|
238
|
-
jobId: handle.job.id,
|
|
239
|
-
error: result.error ?? new Error(fullErrorInfo.message),
|
|
240
|
-
job: handle.job,
|
|
241
|
-
})
|
|
242
|
-
.catch(() => { });
|
|
243
|
-
handle.fail(fullErrorInfo);
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
this.activeJobs--;
|
|
247
|
-
await this.checkForMoreJobs();
|
|
248
|
-
}
|
|
249
|
-
async checkForMoreJobs() {
|
|
250
|
-
if (!this.isRunning) {
|
|
251
|
-
return;
|
|
252
|
-
}
|
|
253
|
-
let hasMore;
|
|
254
|
-
try {
|
|
255
|
-
hasMore = await this.queue.hasJobs();
|
|
256
|
-
}
|
|
257
|
-
catch (error) {
|
|
258
|
-
this.logger.error("Error checking for more jobs: @Error", error);
|
|
259
|
-
return;
|
|
260
|
-
}
|
|
261
|
-
if (hasMore) {
|
|
262
|
-
await this.processNextJob();
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
async processExistingJobs() {
|
|
266
|
-
let hasJobs;
|
|
267
|
-
try {
|
|
268
|
-
hasJobs = await this.queue.hasJobs();
|
|
269
|
-
}
|
|
270
|
-
catch (error) {
|
|
271
|
-
this.logger.error("Error checking for existing jobs: @Error", error);
|
|
272
|
-
return;
|
|
273
|
-
}
|
|
274
|
-
if (hasJobs) {
|
|
275
|
-
// Start processing up to the number of executors
|
|
276
|
-
const promises = [];
|
|
277
|
-
for (let i = 0; i < Math.min(this.executors.length, 5); i++) {
|
|
278
|
-
promises.push(this.processNextJob());
|
|
279
|
-
}
|
|
280
|
-
try {
|
|
281
|
-
await Promise.all(promises);
|
|
282
|
-
}
|
|
283
|
-
catch (error) {
|
|
284
|
-
this.logger.error("Error processing existing jobs: @Error", error);
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
toErrorInfo(error) {
|
|
289
|
-
if (error instanceof Error) {
|
|
290
|
-
return {
|
|
291
|
-
message: error.message,
|
|
292
|
-
stack: error.stack || new Error().stack || "",
|
|
293
|
-
};
|
|
294
|
-
}
|
|
295
|
-
return {
|
|
296
|
-
message: error,
|
|
297
|
-
stack: new Error().stack || "",
|
|
298
|
-
};
|
|
299
|
-
}
|
|
300
|
-
hasCreateDocumentAction(job) {
|
|
301
|
-
for (const action of job.actions) {
|
|
302
|
-
if (action.type === "CREATE_DOCUMENT") {
|
|
303
|
-
return true;
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
for (const operation of job.operations) {
|
|
307
|
-
if (operation.action.type === "CREATE_DOCUMENT") {
|
|
308
|
-
return true;
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
return false;
|
|
312
|
-
}
|
|
313
|
-
async flushDeferredJobs(documentId) {
|
|
314
|
-
const jobs = this.deferredJobs.get(documentId);
|
|
315
|
-
if (!jobs || jobs.length === 0) {
|
|
316
|
-
return;
|
|
317
|
-
}
|
|
318
|
-
this.deferredJobs.delete(documentId);
|
|
319
|
-
for (const job of jobs) {
|
|
320
|
-
try {
|
|
321
|
-
await this.queue.enqueue(job);
|
|
322
|
-
}
|
|
323
|
-
catch (error) {
|
|
324
|
-
this.logger.error("Error re-enqueuing deferred job: @Error", error);
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
formatErrorHistory(errorHistory, currentError, totalAttempts) {
|
|
329
|
-
const allErrors = [...errorHistory, currentError];
|
|
330
|
-
if (allErrors.length === 1) {
|
|
331
|
-
return currentError;
|
|
332
|
-
}
|
|
333
|
-
const messageLines = [`Job failed after ${totalAttempts} attempts:`];
|
|
334
|
-
const stackLines = [];
|
|
335
|
-
allErrors.forEach((error, index) => {
|
|
336
|
-
messageLines.push(`[Attempt ${index + 1}] ${error.message}`);
|
|
337
|
-
stackLines.push(`[Attempt ${index + 1}] Stack trace:\n${error.stack}`);
|
|
338
|
-
});
|
|
339
|
-
return {
|
|
340
|
-
message: messageLines.join("\n"),
|
|
341
|
-
stack: stackLines.join("\n\n"),
|
|
342
|
-
};
|
|
343
|
-
}
|
|
344
|
-
}
|
|
345
|
-
//# sourceMappingURL=simple-job-executor-manager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"simple-job-executor-manager.js","sourceRoot":"","sources":["../../../src/executor/simple-job-executor-manager.ts"],"names":[],"mappings":"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"}
|