hungry-ghost-hive 0.45.0 → 0.46.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/dist/cli/commands/cluster.d.ts.map +1 -1
  2. package/dist/cli/commands/cluster.js +348 -1
  3. package/dist/cli/commands/cluster.js.map +1 -1
  4. package/dist/cli/commands/cluster.test.js +313 -9
  5. package/dist/cli/commands/cluster.test.js.map +1 -1
  6. package/dist/cli/commands/req-spawn.test.d.ts +2 -0
  7. package/dist/cli/commands/req-spawn.test.d.ts.map +1 -0
  8. package/dist/cli/commands/req-spawn.test.js +116 -0
  9. package/dist/cli/commands/req-spawn.test.js.map +1 -0
  10. package/dist/cli/commands/req.d.ts.map +1 -1
  11. package/dist/cli/commands/req.js +21 -13
  12. package/dist/cli/commands/req.js.map +1 -1
  13. package/dist/cluster/cluster-http-server.d.ts +32 -0
  14. package/dist/cluster/cluster-http-server.d.ts.map +1 -1
  15. package/dist/cluster/cluster-http-server.js +42 -0
  16. package/dist/cluster/cluster-http-server.js.map +1 -1
  17. package/dist/cluster/distributed-runtime-coverage.test.js +9 -0
  18. package/dist/cluster/distributed-runtime-coverage.test.js.map +1 -1
  19. package/dist/cluster/distributed-system.test.js +135 -0
  20. package/dist/cluster/distributed-system.test.js.map +1 -1
  21. package/dist/cluster/events.d.ts +23 -0
  22. package/dist/cluster/events.d.ts.map +1 -1
  23. package/dist/cluster/events.js +74 -0
  24. package/dist/cluster/events.js.map +1 -1
  25. package/dist/cluster/heartbeat-manager.d.ts +2 -0
  26. package/dist/cluster/heartbeat-manager.d.ts.map +1 -1
  27. package/dist/cluster/heartbeat-manager.js +42 -6
  28. package/dist/cluster/heartbeat-manager.js.map +1 -1
  29. package/dist/cluster/membership.test.d.ts +2 -0
  30. package/dist/cluster/membership.test.d.ts.map +1 -0
  31. package/dist/cluster/membership.test.js +416 -0
  32. package/dist/cluster/membership.test.js.map +1 -0
  33. package/dist/cluster/partition-safety.test.d.ts +2 -0
  34. package/dist/cluster/partition-safety.test.d.ts.map +1 -0
  35. package/dist/cluster/partition-safety.test.js +440 -0
  36. package/dist/cluster/partition-safety.test.js.map +1 -0
  37. package/dist/cluster/raft-state-machine.d.ts +33 -1
  38. package/dist/cluster/raft-state-machine.d.ts.map +1 -1
  39. package/dist/cluster/raft-state-machine.js +65 -3
  40. package/dist/cluster/raft-state-machine.js.map +1 -1
  41. package/dist/cluster/raft-store.d.ts +26 -1
  42. package/dist/cluster/raft-store.d.ts.map +1 -1
  43. package/dist/cluster/raft-store.js +137 -0
  44. package/dist/cluster/raft-store.js.map +1 -1
  45. package/dist/cluster/replication-lag.test.d.ts +2 -0
  46. package/dist/cluster/replication-lag.test.d.ts.map +1 -0
  47. package/dist/cluster/replication-lag.test.js +239 -0
  48. package/dist/cluster/replication-lag.test.js.map +1 -0
  49. package/dist/cluster/replication.d.ts +2 -2
  50. package/dist/cluster/replication.d.ts.map +1 -1
  51. package/dist/cluster/replication.js +1 -1
  52. package/dist/cluster/replication.js.map +1 -1
  53. package/dist/cluster/runtime.d.ts +78 -0
  54. package/dist/cluster/runtime.d.ts.map +1 -1
  55. package/dist/cluster/runtime.js +400 -13
  56. package/dist/cluster/runtime.js.map +1 -1
  57. package/dist/cluster/state-recovery.test.d.ts +2 -0
  58. package/dist/cluster/state-recovery.test.d.ts.map +1 -0
  59. package/dist/cluster/state-recovery.test.js +310 -0
  60. package/dist/cluster/state-recovery.test.js.map +1 -0
  61. package/dist/cluster/types.d.ts +30 -0
  62. package/dist/cluster/types.d.ts.map +1 -1
  63. package/dist/config/schema.d.ts +48 -0
  64. package/dist/config/schema.d.ts.map +1 -1
  65. package/dist/config/schema.js +11 -0
  66. package/dist/config/schema.js.map +1 -1
  67. package/dist/context-files/generator.js +1 -1
  68. package/dist/context-files/generator.js.map +1 -1
  69. package/dist/context-files/generator.test.js +51 -0
  70. package/dist/context-files/generator.test.js.map +1 -1
  71. package/dist/orchestrator/orphan-recovery.d.ts +1 -1
  72. package/dist/orchestrator/orphan-recovery.d.ts.map +1 -1
  73. package/dist/orchestrator/orphan-recovery.js +4 -4
  74. package/dist/orchestrator/orphan-recovery.js.map +1 -1
  75. package/dist/orchestrator/prompt-templates.d.ts +3 -1
  76. package/dist/orchestrator/prompt-templates.d.ts.map +1 -1
  77. package/dist/orchestrator/prompt-templates.js +45 -8
  78. package/dist/orchestrator/prompt-templates.js.map +1 -1
  79. package/dist/orchestrator/prompt-templates.test.js +210 -0
  80. package/dist/orchestrator/prompt-templates.test.js.map +1 -1
  81. package/dist/orchestrator/scheduler.d.ts +1 -0
  82. package/dist/orchestrator/scheduler.d.ts.map +1 -1
  83. package/dist/orchestrator/scheduler.js +15 -10
  84. package/dist/orchestrator/scheduler.js.map +1 -1
  85. package/dist/orchestrator/scheduler.test.js +97 -6
  86. package/dist/orchestrator/scheduler.test.js.map +1 -1
  87. package/package.json +1 -1
  88. package/src/cli/commands/cluster.test.ts +387 -9
  89. package/src/cli/commands/cluster.ts +486 -1
  90. package/src/cli/commands/req-spawn.test.ts +153 -0
  91. package/src/cli/commands/req.ts +31 -18
  92. package/src/cluster/cluster-http-server.ts +80 -0
  93. package/src/cluster/distributed-runtime-coverage.test.ts +9 -0
  94. package/src/cluster/distributed-system.test.ts +168 -0
  95. package/src/cluster/events.ts +90 -0
  96. package/src/cluster/heartbeat-manager.ts +48 -6
  97. package/src/cluster/membership.test.ts +498 -0
  98. package/src/cluster/partition-safety.test.ts +523 -0
  99. package/src/cluster/raft-state-machine.ts +76 -4
  100. package/src/cluster/raft-store.ts +167 -1
  101. package/src/cluster/replication-lag.test.ts +284 -0
  102. package/src/cluster/replication.ts +6 -0
  103. package/src/cluster/runtime.ts +551 -12
  104. package/src/cluster/state-recovery.test.ts +420 -0
  105. package/src/cluster/types.ts +32 -0
  106. package/src/config/schema.ts +11 -0
  107. package/src/context-files/generator.test.ts +55 -0
  108. package/src/context-files/generator.ts +5 -5
  109. package/src/orchestrator/orphan-recovery.ts +32 -13
  110. package/src/orchestrator/prompt-templates.test.ts +263 -0
  111. package/src/orchestrator/prompt-templates.ts +49 -8
  112. package/src/orchestrator/scheduler.test.ts +129 -6
  113. package/src/orchestrator/scheduler.ts +46 -20
@@ -1,9 +1,11 @@
1
1
  // Licensed under the Hungry Ghost Hive License. See LICENSE.
2
2
  import { join } from 'path';
3
- import { ClusterHttpServer } from './cluster-http-server.js';
3
+ import { queryAll } from '../db/client.js';
4
+ import { REPLICATED_TABLES } from './adapters.js';
5
+ import { ClusterHttpServer, } from './cluster-http-server.js';
4
6
  import { HeartbeatManager } from './heartbeat-manager.js';
5
7
  import { RaftStateMachine } from './raft-state-machine.js';
6
- import { applyRemoteEvents, ensureClusterTables, getAllClusterEvents, getVersionVector, mergeSimilarStories, scanLocalChanges, } from './replication.js';
8
+ import { applyRemoteEvents, ensureClusterTables, getAllClusterEvents, getClusterEventCount, getEffectiveVersionVector, getVersionVector, mergeSimilarStories, pruneClusterEvents, scanLocalChanges, setSnapshotVersionVector, } from './replication.js';
7
9
  export class ClusterRuntime {
8
10
  config;
9
11
  options;
@@ -11,6 +13,11 @@ export class ClusterRuntime {
11
13
  stopping = false;
12
14
  eventCache = [];
13
15
  versionVectorCache = {};
16
+ lastCompactionAt = 0;
17
+ peerLagMap = new Map();
18
+ lastSyncAt = null;
19
+ /** Cached full snapshot refreshed on every sync, served to recovering nodes. */
20
+ cachedSnapshot = null;
14
21
  raft;
15
22
  heartbeat;
16
23
  httpServer;
@@ -27,6 +34,10 @@ export class ClusterRuntime {
27
34
  postJson: (peer, path, body) => this.postJson(peer, path, body),
28
35
  isActive: () => this.started && !this.stopping,
29
36
  handleBackgroundError: error => this.handleBackgroundError(error),
37
+ onPeersUpdated: peers => {
38
+ // Follower received updated peer list from leader via heartbeat
39
+ this.raft.setPeers(peers);
40
+ },
30
41
  });
31
42
  this.httpServer = new ClusterHttpServer(config, {
32
43
  getStatus: () => this.getStatus(),
@@ -34,6 +45,13 @@ export class ClusterRuntime {
34
45
  handleHeartbeat: body => this.heartbeat.handleHeartbeat(body),
35
46
  getDeltaFromCache: (vector, limit) => this.getDeltaFromCache(vector, limit),
36
47
  getVersionVectorCache: () => this.versionVectorCache,
48
+ getReplicationLag: () => this.getReplicationLag(),
49
+ getFencingToken: () => this.raft.getFencingToken(),
50
+ validateFencingToken: token => this.raft.validateFencingToken(token),
51
+ isLeaderLeaseValid: () => this.raft.isLeaderLeaseValid(),
52
+ handleMembershipJoin: body => this.handleMembershipJoin(body),
53
+ handleMembershipLeave: body => this.handleMembershipLeave(body),
54
+ getSnapshot: () => this.cachedSnapshot ?? { version_vector: {}, tables: {} },
37
55
  });
38
56
  }
39
57
  async start() {
@@ -72,6 +90,26 @@ export class ClusterRuntime {
72
90
  return true;
73
91
  return this.raft.role === 'leader';
74
92
  }
93
+ getReplicationLag() {
94
+ return {
95
+ node_id: this.config.node_id,
96
+ total_local_events: this.eventCache.length,
97
+ version_vector: { ...this.versionVectorCache },
98
+ peers: this.raft
99
+ .getPeers()
100
+ .filter(p => p.id !== this.config.node_id)
101
+ .map(p => this.peerLagMap.get(p.id) || {
102
+ peer_id: p.id,
103
+ peer_url: p.url,
104
+ reachable: false,
105
+ events_behind: 0,
106
+ last_sync_at: null,
107
+ last_sync_duration_ms: null,
108
+ last_sync_events_applied: 0,
109
+ }),
110
+ last_sync_at: this.lastSyncAt,
111
+ };
112
+ }
75
113
  getStatus() {
76
114
  const raftState = this.raft.getRaftStoreState();
77
115
  return {
@@ -83,10 +121,14 @@ export class ClusterRuntime {
83
121
  is_leader: this.isLeader(),
84
122
  leader_id: this.raft.leaderId,
85
123
  leader_url: this.raft.getLeaderUrl(),
124
+ fencing_token: this.raft.getFencingToken(),
125
+ leader_lease_valid: this.raft.isLeaderLeaseValid(),
126
+ leader_lease_duration_ms: this.raft.leaderLeaseDurationMs,
86
127
  raft_commit_index: raftState?.commit_index || 0,
87
128
  raft_last_applied: raftState?.last_applied || 0,
88
129
  raft_last_log_index: raftState?.last_log_index || 0,
89
- peers: this.config.peers.map(peer => ({ id: peer.id, url: peer.url })),
130
+ peers: this.raft.getPeers().map(peer => ({ id: peer.id, url: peer.url })),
131
+ is_catching_up: this.raft.isCatchingUp,
90
132
  };
91
133
  }
92
134
  async sync(db) {
@@ -96,49 +138,339 @@ export class ClusterRuntime {
96
138
  imported_events_applied: 0,
97
139
  merged_duplicate_stories: 0,
98
140
  durable_log_entries_appended: 0,
141
+ log_entries_compacted: 0,
142
+ cluster_events_pruned: 0,
143
+ used_snapshot_recovery: false,
144
+ catch_up_applied: 0,
145
+ catch_up_total: 0,
99
146
  };
100
147
  }
101
148
  const hiveDir = this.options.hiveDir || join(process.cwd(), '.hive');
102
149
  this.raft.initializeRaftStore(hiveDir);
103
150
  ensureClusterTables(db, this.config.node_id);
151
+ // Refresh snapshot cache so the HTTP endpoint always serves current data
152
+ this.cachedSnapshot = this.buildSnapshot(db);
104
153
  const localEventsBefore = scanLocalChanges(db, this.config.node_id);
105
- const imported = await this.pullEventsFromPeers(db);
154
+ const { imported, usedSnapshot, catchUpApplied, catchUpTotal } = await this.pullEventsFromPeers(db);
106
155
  const merged = mergeSimilarStories(db, this.config.story_similarity_threshold);
107
- const localEventsAfter = imported > 0 || merged > 0 ? scanLocalChanges(db, this.config.node_id) : 0;
156
+ const localEventsAfter = imported > 0 || merged > 0 || usedSnapshot ? scanLocalChanges(db, this.config.node_id) : 0;
108
157
  this.refreshCache(db);
109
158
  const durableLogEntriesAppended = this.raft.appendClusterEventsToDurableLog(getAllClusterEvents(db));
159
+ // Run compaction if thresholds are met and enough time has elapsed
160
+ const { logCompacted, eventsPruned } = this.maybeCompact(db);
110
161
  return {
111
162
  local_events_emitted: localEventsBefore + localEventsAfter,
112
163
  imported_events_applied: imported,
113
164
  merged_duplicate_stories: merged,
114
165
  durable_log_entries_appended: durableLogEntriesAppended,
166
+ log_entries_compacted: logCompacted,
167
+ cluster_events_pruned: eventsPruned,
168
+ used_snapshot_recovery: usedSnapshot,
169
+ catch_up_applied: catchUpApplied,
170
+ catch_up_total: catchUpTotal,
115
171
  };
116
172
  }
173
+ handleMembershipJoin(request) {
174
+ const peers = this.raft.getPeers();
175
+ const leaderUrl = this.raft.getLeaderUrl();
176
+ // If not the leader, redirect to leader
177
+ if (this.raft.role !== 'leader') {
178
+ return {
179
+ success: false,
180
+ leader_id: this.raft.leaderId,
181
+ leader_url: leaderUrl,
182
+ peers: peers.map(p => ({ id: p.id, url: p.url })),
183
+ term: this.raft.currentTerm,
184
+ };
185
+ }
186
+ // Check if peer already exists
187
+ const existing = peers.find(p => p.id === request.node_id);
188
+ if (existing) {
189
+ // Update URL if changed
190
+ if (existing.url !== request.url) {
191
+ const updated = peers.map(p => p.id === request.node_id ? { id: p.id, url: request.url } : p);
192
+ this.raft.setPeers(updated);
193
+ this.raft.appendDurableEntry('membership_change', {
194
+ action: 'update',
195
+ node_id: request.node_id,
196
+ url: request.url,
197
+ peer_count: updated.length,
198
+ });
199
+ }
200
+ return {
201
+ success: true,
202
+ leader_id: this.raft.leaderId,
203
+ leader_url: this.config.public_url,
204
+ peers: this.raft.getPeers().map(p => ({ id: p.id, url: p.url })),
205
+ term: this.raft.currentTerm,
206
+ };
207
+ }
208
+ // Add new peer
209
+ const newPeer = { id: request.node_id, url: request.url };
210
+ const updated = [...peers, newPeer];
211
+ this.raft.setPeers(updated);
212
+ this.raft.appendDurableEntry('membership_change', {
213
+ action: 'join',
214
+ node_id: request.node_id,
215
+ url: request.url,
216
+ peer_count: updated.length,
217
+ });
218
+ return {
219
+ success: true,
220
+ leader_id: this.raft.leaderId,
221
+ leader_url: this.config.public_url,
222
+ peers: updated.map(p => ({ id: p.id, url: p.url })),
223
+ term: this.raft.currentTerm,
224
+ };
225
+ }
226
+ handleMembershipLeave(request) {
227
+ const peers = this.raft.getPeers();
228
+ // If not the leader, cannot process leave
229
+ if (this.raft.role !== 'leader') {
230
+ return {
231
+ success: false,
232
+ peers: peers.map(p => ({ id: p.id, url: p.url })),
233
+ };
234
+ }
235
+ // Cannot remove self (leader) — leader must transfer leadership first
236
+ if (request.node_id === this.config.node_id) {
237
+ return {
238
+ success: false,
239
+ peers: peers.map(p => ({ id: p.id, url: p.url })),
240
+ };
241
+ }
242
+ const existing = peers.find(p => p.id === request.node_id);
243
+ if (!existing) {
244
+ // Already gone
245
+ return {
246
+ success: true,
247
+ peers: peers.map(p => ({ id: p.id, url: p.url })),
248
+ };
249
+ }
250
+ const updated = peers.filter(p => p.id !== request.node_id);
251
+ this.raft.setPeers(updated);
252
+ this.raft.appendDurableEntry('membership_change', {
253
+ action: 'leave',
254
+ node_id: request.node_id,
255
+ peer_count: updated.length,
256
+ });
257
+ return {
258
+ success: true,
259
+ peers: updated.map(p => ({ id: p.id, url: p.url })),
260
+ };
261
+ }
262
+ maybeCompact(db) {
263
+ const now = Date.now();
264
+ const interval = this.config.compaction_interval_ms ?? 300000;
265
+ // Respect minimum interval between compaction runs
266
+ if (interval > 0 && now - this.lastCompactionAt < interval) {
267
+ return { logCompacted: 0, eventsPruned: 0 };
268
+ }
269
+ let logCompacted = 0;
270
+ let eventsPruned = 0;
271
+ // Compact raft log if threshold exceeded
272
+ const maxLogEntries = this.config.max_log_entries ?? 10000;
273
+ if (maxLogEntries > 0) {
274
+ const logCount = this.raft.getLogEntryCount();
275
+ if (logCount > maxLogEntries) {
276
+ const versionVector = getVersionVector(db);
277
+ const result = this.raft.createSnapshotAndCompact(versionVector);
278
+ logCompacted = result.entries_removed;
279
+ }
280
+ }
281
+ // Prune cluster_events if threshold exceeded
282
+ const maxEvents = this.config.max_cluster_events ?? 50000;
283
+ if (maxEvents > 0) {
284
+ const eventCount = getClusterEventCount(db);
285
+ if (eventCount > maxEvents) {
286
+ eventsPruned = pruneClusterEvents(db, maxEvents);
287
+ if (eventsPruned > 0) {
288
+ this.refreshCache(db);
289
+ }
290
+ }
291
+ }
292
+ if (logCompacted > 0 || eventsPruned > 0) {
293
+ this.lastCompactionAt = now;
294
+ }
295
+ return { logCompacted, eventsPruned };
296
+ }
117
297
  refreshCache(db) {
118
298
  this.eventCache = getAllClusterEvents(db).slice(-20000);
119
299
  this.versionVectorCache = getVersionVector(db);
120
300
  }
121
301
  async pullEventsFromPeers(db) {
122
- if (this.config.peers.length === 0)
123
- return 0;
124
- let applied = 0;
125
- for (const peer of this.config.peers) {
302
+ const peers = this.raft.getPeers();
303
+ if (peers.length === 0) {
304
+ return { imported: 0, usedSnapshot: false, catchUpApplied: 0, catchUpTotal: 0 };
305
+ }
306
+ let imported = 0;
307
+ const syncTimestamp = new Date().toISOString();
308
+ this.lastSyncAt = syncTimestamp;
309
+ for (const peer of peers) {
126
310
  if (peer.id === this.config.node_id)
127
311
  continue;
128
- const localVector = getVersionVector(db);
312
+ const localVector = getEffectiveVersionVector(db);
313
+ const syncStart = Date.now();
129
314
  const response = await this.requestDelta(peer, localVector, 4000);
130
- if (!response || response.events.length === 0)
315
+ if (!response) {
316
+ this.peerLagMap.set(peer.id, {
317
+ peer_id: peer.id,
318
+ peer_url: peer.url,
319
+ reachable: false,
320
+ events_behind: 0,
321
+ last_sync_at: syncTimestamp,
322
+ last_sync_duration_ms: Date.now() - syncStart,
323
+ last_sync_events_applied: 0,
324
+ });
325
+ continue;
326
+ }
327
+ // If the peer advertises a higher fencing token, step down
328
+ if (typeof response.fencing_token === 'number' &&
329
+ response.fencing_token > this.raft.currentTerm) {
330
+ this.raft.stepDown(response.fencing_token, null);
331
+ }
332
+ // Detect if the delta is insufficient (peer's log was truncated past our position)
333
+ if (this.isDeltaInsufficient(localVector, response.version_vector, response.events)) {
334
+ const recovery = await this.recoverFromSnapshot(db, peer);
335
+ if (recovery !== null) {
336
+ this.peerLagMap.set(peer.id, {
337
+ peer_id: peer.id,
338
+ peer_url: peer.url,
339
+ reachable: true,
340
+ events_behind: 0,
341
+ last_sync_at: syncTimestamp,
342
+ last_sync_duration_ms: Date.now() - syncStart,
343
+ last_sync_events_applied: recovery.applied,
344
+ });
345
+ return {
346
+ imported: 0,
347
+ usedSnapshot: true,
348
+ catchUpApplied: recovery.applied,
349
+ catchUpTotal: recovery.total,
350
+ };
351
+ }
352
+ // Snapshot recovery failed — fall through and apply whatever delta we have
353
+ }
354
+ const eventsBehind = response.events.length;
355
+ const peerApplied = eventsBehind > 0 ? applyRemoteEvents(db, this.config.node_id, response.events) : 0;
356
+ imported += peerApplied;
357
+ this.peerLagMap.set(peer.id, {
358
+ peer_id: peer.id,
359
+ peer_url: peer.url,
360
+ reachable: true,
361
+ events_behind: eventsBehind,
362
+ last_sync_at: syncTimestamp,
363
+ last_sync_duration_ms: Date.now() - syncStart,
364
+ last_sync_events_applied: peerApplied,
365
+ });
366
+ }
367
+ // If we had been catching up and now the effective vector matches peers, mark done
368
+ if (this.raft.isCatchingUp) {
369
+ this.raft.isCatchingUp = false;
370
+ }
371
+ return { imported, usedSnapshot: false, catchUpApplied: 0, catchUpTotal: 0 };
372
+ }
373
+ /**
374
+ * Returns true when the delta response is missing events the peer should have.
375
+ * This happens when the peer's event cache has been truncated (log compaction)
376
+ * and can no longer provide all events since our last known version.
377
+ */
378
+ isDeltaInsufficient(localVector, peerVector, receivedEvents) {
379
+ // Count how many events we actually received per actor
380
+ const received = {};
381
+ for (const event of receivedEvents) {
382
+ received[event.version.actor_id] = (received[event.version.actor_id] ?? 0) + 1;
383
+ }
384
+ for (const [actorId, peerCounter] of Object.entries(peerVector)) {
385
+ const localCounter = localVector[actorId] ?? 0;
386
+ const needed = peerCounter - localCounter;
387
+ if (needed <= 0)
131
388
  continue;
132
- applied += applyRemoteEvents(db, this.config.node_id, response.events);
389
+ const receivedCount = received[actorId] ?? 0;
390
+ if (receivedCount < needed) {
391
+ // We're missing events for this actor that the peer should have
392
+ return true;
393
+ }
133
394
  }
134
- return applied;
395
+ return false;
396
+ }
397
+ /**
398
+ * Requests a full snapshot from the given peer and applies it locally.
399
+ * Marks the node as no longer catching up once complete.
400
+ * Returns { applied, total } on success, null on failure.
401
+ */
402
+ async recoverFromSnapshot(db, peer) {
403
+ this.raft.isCatchingUp = true;
404
+ this.raft.appendDurableEntry('runtime', {
405
+ event: 'snapshot_recovery_start',
406
+ node_id: this.config.node_id,
407
+ peer_id: peer.id,
408
+ });
409
+ const snapshot = await this.requestSnapshot(peer);
410
+ if (!snapshot) {
411
+ return null;
412
+ }
413
+ const { applied, total } = this.applySnapshot(db, snapshot);
414
+ this.raft.isCatchingUp = false;
415
+ this.raft.appendDurableEntry('runtime', {
416
+ event: 'snapshot_recovery_complete',
417
+ node_id: this.config.node_id,
418
+ peer_id: peer.id,
419
+ rows_applied: applied,
420
+ rows_total: total,
421
+ });
422
+ return { applied, total };
423
+ }
424
+ /**
425
+ * Applies a snapshot to the local database, upserting all rows from all tables.
426
+ * Stores the snapshot's version vector so future delta requests start from here.
427
+ */
428
+ applySnapshot(db, snapshot) {
429
+ let applied = 0;
430
+ let total = 0;
431
+ for (const adapter of REPLICATED_TABLES) {
432
+ const rows = snapshot.tables[adapter.table];
433
+ if (!rows)
434
+ continue;
435
+ total += rows.length;
436
+ for (const row of rows) {
437
+ adapter.upsert(db, row.payload);
438
+ applied++;
439
+ }
440
+ }
441
+ // Record the snapshot version vector so future delta requests
442
+ // only ask for events newer than this snapshot
443
+ setSnapshotVersionVector(db, snapshot.version_vector);
444
+ return { applied, total };
445
+ }
446
+ /**
447
+ * Builds a full snapshot of all replicated tables from the current db state.
448
+ * Called during sync to keep cachedSnapshot fresh for the HTTP endpoint.
449
+ */
450
+ buildSnapshot(db) {
451
+ const tables = {};
452
+ for (const adapter of REPLICATED_TABLES) {
453
+ const rows = queryAll(db, adapter.selectSql);
454
+ tables[adapter.table] = rows.map(row => ({
455
+ rowId: adapter.rowId(row),
456
+ payload: adapter.payload(row),
457
+ }));
458
+ }
459
+ return {
460
+ version_vector: getVersionVector(db),
461
+ tables,
462
+ };
135
463
  }
136
464
  async requestDelta(peer, versionVector, limit) {
137
465
  return this.postJson(peer, '/cluster/v1/events/delta', {
138
466
  version_vector: versionVector,
139
467
  limit,
468
+ fencing_token: this.raft.getFencingToken(),
140
469
  });
141
470
  }
471
+ async requestSnapshot(peer) {
472
+ return this.getJson(peer, '/cluster/v1/snapshot');
473
+ }
142
474
  getDeltaFromCache(remoteVersionVector, limit) {
143
475
  return this.eventCache
144
476
  .filter(event => {
@@ -155,6 +487,11 @@ export class ClusterRuntime {
155
487
  body,
156
488
  });
157
489
  }
490
+ async getJson(peer, path) {
491
+ const normalizedBase = peer.url.endsWith('/') ? peer.url : `${peer.url}/`;
492
+ const url = new URL(path.replace(/^\//, ''), normalizedBase).toString();
493
+ return fetchClusterStatusOrPostJson(url, this.config.request_timeout_ms, this.config.auth_token, { method: 'GET' });
494
+ }
158
495
  handleBackgroundError(error) {
159
496
  if (!this.started || this.stopping)
160
497
  return;
@@ -171,6 +508,48 @@ export class ClusterRuntime {
171
508
  throw new Error(`Cluster auth_token is required when listen_host is not loopback (received: ${this.config.listen_host})`);
172
509
  }
173
510
  }
511
+ export async function fetchReplicationLag(config) {
512
+ if (!config.enabled)
513
+ return null;
514
+ const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
515
+ const url = `http://${host}:${config.listen_port}/cluster/v1/replication-lag`;
516
+ return fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, { method: 'GET' });
517
+ }
518
+ /**
519
+ * Fetches recent cluster events from the local runtime via the delta endpoint.
520
+ * Uses an empty version vector to request recent events up to the given limit.
521
+ */
522
+ export async function fetchLocalClusterEvents(config, limit = 50) {
523
+ if (!config.enabled)
524
+ return null;
525
+ const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
526
+ const url = `http://${host}:${config.listen_port}/cluster/v1/events/delta`;
527
+ const response = await fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, { method: 'POST', body: { version_vector: {}, limit } });
528
+ return response?.events ?? null;
529
+ }
530
+ /**
531
+ * POSTs to the local cluster runtime at the given path.
532
+ */
533
+ export async function postToLocalCluster(config, path, body) {
534
+ if (!config.enabled)
535
+ return null;
536
+ const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
537
+ const url = `http://${host}:${config.listen_port}${path}`;
538
+ return fetchClusterStatusOrPostJson(url, config.request_timeout_ms, config.auth_token, {
539
+ method: 'POST',
540
+ body,
541
+ });
542
+ }
543
+ /**
544
+ * POSTs to a peer cluster node at the given URL and path.
545
+ */
546
+ export async function postToPeerCluster(peerUrl, path, body, options) {
547
+ const url = `${peerUrl.replace(/\/$/, '')}${path}`;
548
+ return fetchClusterStatusOrPostJson(url, options.timeoutMs, options.authToken, {
549
+ method: 'POST',
550
+ body,
551
+ });
552
+ }
174
553
  export async function fetchLocalClusterStatus(config) {
175
554
  if (!config.enabled) {
176
555
  return {
@@ -182,10 +561,14 @@ export async function fetchLocalClusterStatus(config) {
182
561
  is_leader: true,
183
562
  leader_id: config.node_id,
184
563
  leader_url: null,
564
+ fencing_token: 0,
565
+ leader_lease_valid: true,
566
+ leader_lease_duration_ms: config.leader_lease_ms ?? config.heartbeat_interval_ms * 3,
185
567
  raft_commit_index: 0,
186
568
  raft_last_applied: 0,
187
569
  raft_last_log_index: 0,
188
570
  peers: config.peers.map(peer => ({ id: peer.id, url: peer.url })),
571
+ is_catching_up: false,
189
572
  };
190
573
  }
191
574
  const host = config.listen_host === '0.0.0.0' ? '127.0.0.1' : config.listen_host;
@@ -228,10 +611,14 @@ function parseClusterStatus(input) {
228
611
  is_leader: input.is_leader === true,
229
612
  leader_id: typeof input.leader_id === 'string' ? input.leader_id : null,
230
613
  leader_url: typeof input.leader_url === 'string' ? input.leader_url : null,
614
+ fencing_token: toInt(input.fencing_token),
615
+ leader_lease_valid: input.leader_lease_valid === true,
616
+ leader_lease_duration_ms: toInt(input.leader_lease_duration_ms),
231
617
  raft_commit_index: toInt(input.raft_commit_index),
232
618
  raft_last_applied: toInt(input.raft_last_applied),
233
619
  raft_last_log_index: toInt(input.raft_last_log_index),
234
620
  peers,
621
+ is_catching_up: input.is_catching_up === true,
235
622
  };
236
623
  }
237
624
  async function fetchClusterStatusOrPostJson(url, timeoutMs, authToken, options) {
@@ -1 +1 @@
1
- {"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/cluster/runtime.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/cluster/runtime.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=state-recovery.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"state-recovery.test.d.ts","sourceRoot":"","sources":["../../src/cluster/state-recovery.test.ts"],"names":[],"mappings":""}