@ceramicnetwork/indexing 1.1.0-rc.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 (98) hide show
  1. package/README.md +31 -0
  2. package/lib/__tests__/chunks.util.d.ts +2 -0
  3. package/lib/__tests__/chunks.util.d.ts.map +1 -0
  4. package/lib/__tests__/chunks.util.js +8 -0
  5. package/lib/__tests__/chunks.util.js.map +1 -0
  6. package/lib/__tests__/read-csv-fixture.util.d.ts +5 -0
  7. package/lib/__tests__/read-csv-fixture.util.d.ts.map +1 -0
  8. package/lib/__tests__/read-csv-fixture.util.js +35 -0
  9. package/lib/__tests__/read-csv-fixture.util.js.map +1 -0
  10. package/lib/as-table-name.util.d.ts +3 -0
  11. package/lib/as-table-name.util.d.ts.map +1 -0
  12. package/lib/as-table-name.util.js +4 -0
  13. package/lib/as-table-name.util.js.map +1 -0
  14. package/lib/build-indexing.d.ts +13 -0
  15. package/lib/build-indexing.d.ts.map +1 -0
  16. package/lib/build-indexing.js +55 -0
  17. package/lib/build-indexing.js.map +1 -0
  18. package/lib/column-name.util.d.ts +2 -0
  19. package/lib/column-name.util.d.ts.map +1 -0
  20. package/lib/column-name.util.js +5 -0
  21. package/lib/column-name.util.js.map +1 -0
  22. package/lib/config.d.ts +2 -0
  23. package/lib/config.d.ts.map +1 -0
  24. package/lib/config.js +2 -0
  25. package/lib/config.js.map +1 -0
  26. package/lib/database-index-api.d.ts +94 -0
  27. package/lib/database-index-api.d.ts.map +1 -0
  28. package/lib/database-index-api.js +228 -0
  29. package/lib/database-index-api.js.map +1 -0
  30. package/lib/history-sync/interfaces.d.ts +52 -0
  31. package/lib/history-sync/interfaces.d.ts.map +1 -0
  32. package/lib/history-sync/interfaces.js +11 -0
  33. package/lib/history-sync/interfaces.js.map +1 -0
  34. package/lib/history-sync/sync-api.d.ts +82 -0
  35. package/lib/history-sync/sync-api.d.ts.map +1 -0
  36. package/lib/history-sync/sync-api.js +276 -0
  37. package/lib/history-sync/sync-api.js.map +1 -0
  38. package/lib/history-sync/utils.d.ts +15 -0
  39. package/lib/history-sync/utils.d.ts.map +1 -0
  40. package/lib/history-sync/utils.js +23 -0
  41. package/lib/history-sync/utils.js.map +1 -0
  42. package/lib/history-sync/workers/rebuild-anchor.d.ts +15 -0
  43. package/lib/history-sync/workers/rebuild-anchor.d.ts.map +1 -0
  44. package/lib/history-sync/workers/rebuild-anchor.js +96 -0
  45. package/lib/history-sync/workers/rebuild-anchor.js.map +1 -0
  46. package/lib/history-sync/workers/sync.d.ts +24 -0
  47. package/lib/history-sync/workers/sync.d.ts.map +1 -0
  48. package/lib/history-sync/workers/sync.js +77 -0
  49. package/lib/history-sync/workers/sync.js.map +1 -0
  50. package/lib/index-query-not-available.error.d.ts +5 -0
  51. package/lib/index-query-not-available.error.d.ts.map +1 -0
  52. package/lib/index-query-not-available.error.js +6 -0
  53. package/lib/index-query-not-available.error.js.map +1 -0
  54. package/lib/index.d.ts +7 -0
  55. package/lib/index.d.ts.map +1 -0
  56. package/lib/index.js +6 -0
  57. package/lib/index.js.map +1 -0
  58. package/lib/insertion-order.d.ts +15 -0
  59. package/lib/insertion-order.d.ts.map +1 -0
  60. package/lib/insertion-order.js +180 -0
  61. package/lib/insertion-order.js.map +1 -0
  62. package/lib/local-index-api.d.ts +30 -0
  63. package/lib/local-index-api.d.ts.map +1 -0
  64. package/lib/local-index-api.js +118 -0
  65. package/lib/local-index-api.js.map +1 -0
  66. package/lib/make-index-api.d.ts +9 -0
  67. package/lib/make-index-api.d.ts.map +1 -0
  68. package/lib/make-index-api.js +27 -0
  69. package/lib/make-index-api.js.map +1 -0
  70. package/lib/migrations/1-create-model-table.d.ts +34 -0
  71. package/lib/migrations/1-create-model-table.d.ts.map +1 -0
  72. package/lib/migrations/1-create-model-table.js +243 -0
  73. package/lib/migrations/1-create-model-table.js.map +1 -0
  74. package/lib/migrations/cdb-schema-verification.d.ts +15 -0
  75. package/lib/migrations/cdb-schema-verification.d.ts.map +1 -0
  76. package/lib/migrations/cdb-schema-verification.js +272 -0
  77. package/lib/migrations/cdb-schema-verification.js.map +1 -0
  78. package/lib/parse-pagination.d.ts +18 -0
  79. package/lib/parse-pagination.d.ts.map +1 -0
  80. package/lib/parse-pagination.js +23 -0
  81. package/lib/parse-pagination.js.map +1 -0
  82. package/lib/query-filter-converter.d.ts +12 -0
  83. package/lib/query-filter-converter.d.ts.map +1 -0
  84. package/lib/query-filter-converter.js +231 -0
  85. package/lib/query-filter-converter.js.map +1 -0
  86. package/lib/query-filter-parser.d.ts +63 -0
  87. package/lib/query-filter-parser.d.ts.map +1 -0
  88. package/lib/query-filter-parser.js +178 -0
  89. package/lib/query-filter-parser.js.map +1 -0
  90. package/lib/tables-manager.d.ts +44 -0
  91. package/lib/tables-manager.d.ts.map +1 -0
  92. package/lib/tables-manager.js +218 -0
  93. package/lib/tables-manager.js.map +1 -0
  94. package/lib/unsupported-ordering-error.d.ts +4 -0
  95. package/lib/unsupported-ordering-error.d.ts.map +1 -0
  96. package/lib/unsupported-ordering-error.js +6 -0
  97. package/lib/unsupported-ordering-error.js.map +1 -0
  98. package/package.json +64 -0
@@ -0,0 +1,11 @@
1
+ export const REBUILD_ANCHOR_JOB = 'rebuildAnchorJob';
2
+ export const HISTORY_SYNC_JOB = 'historySyncJob';
3
+ export const CONTINUOUS_SYNC_JOB = 'continuousSyncJob';
4
+ export var SyncJobType;
5
+ (function (SyncJobType) {
6
+ SyncJobType[SyncJobType["Catchup"] = 0] = "Catchup";
7
+ SyncJobType[SyncJobType["Reorg"] = 1] = "Reorg";
8
+ SyncJobType[SyncJobType["Full"] = 2] = "Full";
9
+ SyncJobType[SyncJobType["Continuous"] = 3] = "Continuous";
10
+ })(SyncJobType || (SyncJobType = {}));
11
+ //# sourceMappingURL=interfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../src/history-sync/interfaces.ts"],"names":[],"mappings":"AA6CA,MAAM,CAAC,MAAM,kBAAkB,GAAG,kBAAkB,CAAA;AASpD,MAAM,CAAC,MAAM,gBAAgB,GAAG,gBAAgB,CAAA;AAChD,MAAM,CAAC,MAAM,mBAAmB,GAAG,mBAAmB,CAAA;AAGtD,MAAM,CAAN,IAAY,WAKX;AALD,WAAY,WAAW;IACrB,mDAAO,CAAA;IACP,+CAAK,CAAA;IACL,6CAAI,CAAA;IACJ,yDAAU,CAAA;AACZ,CAAC,EALW,WAAW,KAAX,WAAW,QAKtB"}
@@ -0,0 +1,82 @@
1
+ import { type BlockProofsListenerEvent } from '@ceramicnetwork/anchor-listener';
2
+ import type { DiagnosticsLogger } from '@ceramicnetwork/common';
3
+ import type { Provider } from '@ethersproject/providers';
4
+ import type { LocalIndexApi } from '../local-index-api.js';
5
+ import { HandleCommit, ISyncApi, IpfsService, SyncJobData, type SyncJob } from './interfaces.js';
6
+ import { SyncCompleteData } from './workers/sync.js';
7
+ export declare const BLOCK_CONFIRMATIONS = 20;
8
+ export declare const INITIAL_INDEXING_BLOCKS: Record<string, number>;
9
+ export declare const STATE_TABLE_NAME = "ceramic_indexing_state";
10
+ declare type StoredState = {
11
+ processedBlockHash?: string;
12
+ processedBlockNumber?: number;
13
+ };
14
+ export declare type SyncConfig = {
15
+ db: string;
16
+ on?: boolean;
17
+ };
18
+ export interface ActiveSyncStatus {
19
+ startBlock: number;
20
+ currentBlock: number;
21
+ endBlock: number;
22
+ models: Array<string>;
23
+ createdAt: Date;
24
+ startedAt: Date;
25
+ }
26
+ export interface ContinuousSyncStatus {
27
+ startBlock: number;
28
+ latestBlock: number;
29
+ confirmations: number;
30
+ currentBlock: number;
31
+ models: Array<string>;
32
+ }
33
+ export interface PendingSyncStatus {
34
+ startBlock: number;
35
+ endBlock: number;
36
+ models: Array<string>;
37
+ createdAt: Date;
38
+ }
39
+ export interface SyncStatus {
40
+ activeSyncs: Array<ActiveSyncStatus>;
41
+ continuousSync: Array<ContinuousSyncStatus>;
42
+ pendingSyncs: Array<PendingSyncStatus>;
43
+ }
44
+ export declare class SyncApi implements ISyncApi {
45
+ private readonly syncConfig;
46
+ private readonly ipfsService;
47
+ private readonly handleCommit;
48
+ private readonly localIndex;
49
+ private readonly diagnosticsLogger;
50
+ readonly modelsToSync: Set<string>;
51
+ readonly modelsToHistoricSync: Map<string, number>;
52
+ private readonly dataSource;
53
+ private readonly jobQueue;
54
+ private subscription;
55
+ private provider;
56
+ private chainId;
57
+ private initialIndexingBlock;
58
+ private periodicStatusLogger;
59
+ private currentBlock;
60
+ private startBlock;
61
+ constructor(syncConfig: SyncConfig, ipfsService: IpfsService, handleCommit: HandleCommit, localIndex: LocalIndexApi, diagnosticsLogger: DiagnosticsLogger);
62
+ init(provider: Provider): Promise<void>;
63
+ _initJobQueue(): Promise<void>;
64
+ _upsertModelForHistoricSync(model: string): void;
65
+ _initModelsToSync(): Promise<void>;
66
+ _initStateTable(): Promise<StoredState>;
67
+ _initBlockSubscription(expectedParentHash?: string): void;
68
+ _handleBlockProofs({ block, reorganized }: BlockProofsListenerEvent): Promise<void>;
69
+ _addSyncJob(type: SyncJob, data: SyncJobData): Promise<void>;
70
+ _updateStoredState(state: StoredState): Promise<void>;
71
+ _logSyncStatus(): Promise<void>;
72
+ syncStatus(): Promise<SyncStatus>;
73
+ _initPeriodicStatusLogger(): void;
74
+ startModelSync(models: string | string[], startBlock?: number, knownEndBlock?: number): Promise<void>;
75
+ stopModelSync(models: string | string[]): Promise<void>;
76
+ syncCompletedForModel(data: SyncCompleteData): void;
77
+ syncComplete(model: string): boolean;
78
+ shutdown(): Promise<void>;
79
+ get enabled(): boolean | undefined;
80
+ }
81
+ export {};
82
+ //# sourceMappingURL=sync-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync-api.d.ts","sourceRoot":"","sources":["../../src/history-sync/sync-api.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,276 @@
1
+ import knex from 'knex';
2
+ import { createBlockProofsListener, } from '@ceramicnetwork/anchor-listener';
3
+ import { JobQueue } from '@ceramicnetwork/job-queue';
4
+ import { catchError, concatMap, defer, interval, mergeMap } from 'rxjs';
5
+ import { CONTINUOUS_SYNC_JOB, HISTORY_SYNC_JOB, REBUILD_ANCHOR_JOB, SyncJobType, } from './interfaces.js';
6
+ import { RebuildAnchorWorker } from './workers/rebuild-anchor.js';
7
+ import { createContinuousSyncJob, createHistorySyncJob, SyncWorker, } from './workers/sync.js';
8
+ const SYNC_STATUS_LOG_INTERVAL = 60000;
9
+ export const BLOCK_CONFIRMATIONS = 20;
10
+ export const INITIAL_INDEXING_BLOCKS = {
11
+ 'eip155:1': 16695723,
12
+ 'eip155:5': 8503000,
13
+ 'eip155:100': 26511896,
14
+ };
15
+ export const STATE_TABLE_NAME = 'ceramic_indexing_state';
16
+ export class SyncApi {
17
+ constructor(syncConfig, ipfsService, handleCommit, localIndex, diagnosticsLogger) {
18
+ this.syncConfig = syncConfig;
19
+ this.ipfsService = ipfsService;
20
+ this.handleCommit = handleCommit;
21
+ this.localIndex = localIndex;
22
+ this.diagnosticsLogger = diagnosticsLogger;
23
+ this.modelsToSync = new Set();
24
+ this.modelsToHistoricSync = new Map();
25
+ if (!this.syncConfig.on)
26
+ return;
27
+ this.dataSource = knex({ client: 'pg', connection: this.syncConfig.db });
28
+ this.jobQueue = new JobQueue(this.syncConfig.db, this.diagnosticsLogger);
29
+ }
30
+ async init(provider) {
31
+ if (!this.syncConfig.on)
32
+ return;
33
+ this.provider = provider;
34
+ const chainIdNumber = (await provider.getNetwork()).chainId;
35
+ this.chainId = `eip155:${chainIdNumber}`;
36
+ this.initialIndexingBlock = INITIAL_INDEXING_BLOCKS[this.chainId] || 0;
37
+ const [latestBlock, { processedBlockNumber }] = await Promise.all([
38
+ this.provider.getBlock(-BLOCK_CONFIRMATIONS),
39
+ this._initStateTable(),
40
+ this._initModelsToSync(),
41
+ this._initJobQueue(),
42
+ ]);
43
+ this.startBlock = latestBlock.number;
44
+ this._initBlockSubscription(latestBlock.hash);
45
+ if (processedBlockNumber == null) {
46
+ await this._addSyncJob(HISTORY_SYNC_JOB, {
47
+ jobType: SyncJobType.Catchup,
48
+ fromBlock: this.initialIndexingBlock,
49
+ toBlock: latestBlock.number,
50
+ models: Array.from(this.modelsToSync),
51
+ });
52
+ }
53
+ else if (processedBlockNumber < latestBlock.number) {
54
+ await this._addSyncJob(HISTORY_SYNC_JOB, {
55
+ jobType: SyncJobType.Catchup,
56
+ fromBlock: processedBlockNumber,
57
+ toBlock: latestBlock.number,
58
+ models: Array.from(this.modelsToSync),
59
+ });
60
+ }
61
+ this._initPeriodicStatusLogger();
62
+ }
63
+ async _initJobQueue() {
64
+ await this.jobQueue.init({
65
+ [REBUILD_ANCHOR_JOB]: new RebuildAnchorWorker(this.ipfsService, this.handleCommit, this.diagnosticsLogger),
66
+ [HISTORY_SYNC_JOB]: new SyncWorker(this.provider, this.jobQueue, this.chainId, this.diagnosticsLogger, this.syncCompletedForModel.bind(this)),
67
+ [CONTINUOUS_SYNC_JOB]: new SyncWorker(this.provider, this.jobQueue, this.chainId, this.diagnosticsLogger, this.syncCompletedForModel.bind(this)),
68
+ });
69
+ }
70
+ _upsertModelForHistoricSync(model) {
71
+ let existing = this.modelsToHistoricSync.get(model);
72
+ if (existing) {
73
+ existing += 1;
74
+ }
75
+ else {
76
+ existing = 1;
77
+ }
78
+ this.modelsToHistoricSync.set(model, existing);
79
+ }
80
+ async _initModelsToSync() {
81
+ const streamsIds = await this.localIndex.indexedModels();
82
+ for (const id of streamsIds) {
83
+ this.modelsToSync.add(id.toString());
84
+ }
85
+ }
86
+ async _initStateTable() {
87
+ const exists = await this.dataSource.schema.hasTable(STATE_TABLE_NAME);
88
+ if (!exists) {
89
+ await this.dataSource.schema.createTable(STATE_TABLE_NAME, function (table) {
90
+ table.string('processed_block_hash', 1024);
91
+ table.integer('processed_block_number');
92
+ });
93
+ await this.dataSource
94
+ .into(STATE_TABLE_NAME)
95
+ .insert({ processed_block_hash: null, processed_block_number: null });
96
+ return {};
97
+ }
98
+ const state = await this.dataSource.from(STATE_TABLE_NAME).first();
99
+ return {
100
+ processedBlockHash: state['processed_block_hash'],
101
+ processedBlockNumber: state['processed_block_number'],
102
+ };
103
+ }
104
+ _initBlockSubscription(expectedParentHash) {
105
+ this.subscription = createBlockProofsListener({
106
+ confirmations: BLOCK_CONFIRMATIONS,
107
+ chainId: this.chainId,
108
+ provider: this.provider,
109
+ expectedParentHash,
110
+ })
111
+ .pipe(mergeMap((blockProofs) => this._handleBlockProofs(blockProofs)), catchError((err) => {
112
+ this.diagnosticsLogger.err(`Error received during continuous sync: ${err}`);
113
+ throw err;
114
+ }))
115
+ .subscribe();
116
+ }
117
+ async _handleBlockProofs({ block, reorganized }) {
118
+ this.currentBlock = block.number;
119
+ if (reorganized) {
120
+ await this._addSyncJob(HISTORY_SYNC_JOB, {
121
+ jobType: SyncJobType.Reorg,
122
+ fromBlock: block.number - BLOCK_CONFIRMATIONS,
123
+ toBlock: block.number,
124
+ models: Array.from(this.modelsToSync),
125
+ });
126
+ }
127
+ else {
128
+ await this._addSyncJob(CONTINUOUS_SYNC_JOB, {
129
+ jobType: SyncJobType.Continuous,
130
+ fromBlock: block.number,
131
+ toBlock: block.number,
132
+ models: Array.from(this.modelsToSync),
133
+ });
134
+ }
135
+ await this._updateStoredState({
136
+ processedBlockHash: block.hash,
137
+ processedBlockNumber: block.number,
138
+ });
139
+ }
140
+ async _addSyncJob(type, data) {
141
+ if (data.models.length === 0) {
142
+ return;
143
+ }
144
+ if (data.jobType != SyncJobType.Reorg && data.jobType != SyncJobType.Continuous) {
145
+ for (const model of data.models) {
146
+ this._upsertModelForHistoricSync(model);
147
+ }
148
+ }
149
+ const job = type === HISTORY_SYNC_JOB ? createHistorySyncJob(data) : createContinuousSyncJob(data);
150
+ this.jobQueue.addJob(job);
151
+ }
152
+ async _updateStoredState(state) {
153
+ await this.dataSource.from(STATE_TABLE_NAME).update({
154
+ processed_block_hash: state.processedBlockHash,
155
+ processed_block_number: state.processedBlockNumber,
156
+ });
157
+ }
158
+ async _logSyncStatus() {
159
+ const syncStatus = await this.syncStatus();
160
+ this.diagnosticsLogger.imp(`Logging state of running ComposeDB syncs\n ${JSON.stringify(syncStatus, null, 3)}`);
161
+ }
162
+ async syncStatus() {
163
+ const [activeJobs, pendingJobs] = await Promise.all([
164
+ this.jobQueue.getJobs('active', [CONTINUOUS_SYNC_JOB, HISTORY_SYNC_JOB]),
165
+ this.jobQueue.getJobs('created', [CONTINUOUS_SYNC_JOB, HISTORY_SYNC_JOB]),
166
+ ]);
167
+ const historySyncJobs = activeJobs[HISTORY_SYNC_JOB] || [];
168
+ const continuousSyncJobs = activeJobs[CONTINUOUS_SYNC_JOB] || pendingJobs[CONTINUOUS_SYNC_JOB] || [];
169
+ const pendingSyncJobs = pendingJobs[HISTORY_SYNC_JOB] || [];
170
+ return {
171
+ activeSyncs: historySyncJobs.map((job) => {
172
+ const jobData = job.data;
173
+ return {
174
+ currentBlock: jobData.currentBlock || jobData.fromBlock,
175
+ startBlock: jobData.fromBlock,
176
+ endBlock: jobData.toBlock,
177
+ models: jobData.models,
178
+ createdAt: job.createdOn,
179
+ startedAt: job.startedOn,
180
+ };
181
+ }),
182
+ continuousSync: continuousSyncJobs.length > 0
183
+ ? continuousSyncJobs.map((job) => {
184
+ const jobData = job.data;
185
+ return {
186
+ startBlock: this.startBlock,
187
+ latestBlock: this.currentBlock,
188
+ confirmations: BLOCK_CONFIRMATIONS,
189
+ currentBlock: jobData.fromBlock,
190
+ models: jobData.models,
191
+ };
192
+ })
193
+ : [
194
+ {
195
+ startBlock: this.startBlock,
196
+ latestBlock: this.currentBlock,
197
+ confirmations: BLOCK_CONFIRMATIONS,
198
+ currentBlock: this.currentBlock - BLOCK_CONFIRMATIONS,
199
+ models: Array.from(this.modelsToSync),
200
+ },
201
+ ],
202
+ pendingSyncs: pendingSyncJobs.map((job) => {
203
+ const jobData = job.data;
204
+ return {
205
+ startBlock: jobData.fromBlock,
206
+ endBlock: jobData.toBlock,
207
+ models: jobData.models,
208
+ createdAt: job.createdOn,
209
+ };
210
+ }),
211
+ };
212
+ }
213
+ _initPeriodicStatusLogger() {
214
+ this.periodicStatusLogger = interval(SYNC_STATUS_LOG_INTERVAL)
215
+ .pipe(concatMap(() => {
216
+ return defer(async () => await this._logSyncStatus());
217
+ }))
218
+ .subscribe();
219
+ }
220
+ async startModelSync(models, startBlock = this.initialIndexingBlock, knownEndBlock) {
221
+ if (!this.syncConfig.on)
222
+ return;
223
+ const modelIds = Array.isArray(models) ? models : [models];
224
+ for (const id of modelIds) {
225
+ const modelId = id.toString();
226
+ this.modelsToSync.add(modelId);
227
+ }
228
+ const endBlock = knownEndBlock ??
229
+ (await this.provider.getBlock('latest').then(({ number }) => number - BLOCK_CONFIRMATIONS));
230
+ await this._addSyncJob(HISTORY_SYNC_JOB, {
231
+ jobType: SyncJobType.Full,
232
+ fromBlock: startBlock,
233
+ toBlock: endBlock,
234
+ models: modelIds,
235
+ });
236
+ }
237
+ async stopModelSync(models) {
238
+ if (!this.syncConfig.on)
239
+ return;
240
+ const modelIds = Array.isArray(models) ? models : [models];
241
+ for (const id of modelIds) {
242
+ this.modelsToSync.delete(id.toString());
243
+ }
244
+ this.diagnosticsLogger.warn(`Stopped syncing models ${models}. Syncs that are currently running will not be stopped/cancelled but this is a temporary state and will be implemented in a future version.`);
245
+ }
246
+ syncCompletedForModel(data) {
247
+ if (data.jobType !== SyncJobType.Reorg && data.jobType !== SyncJobType.Continuous) {
248
+ const existing = this.modelsToHistoricSync.get(data.modelId);
249
+ if (existing) {
250
+ if (existing <= 1) {
251
+ this.modelsToHistoricSync.delete(data.modelId);
252
+ }
253
+ else {
254
+ this.modelsToHistoricSync.set(data.modelId, existing - 1);
255
+ }
256
+ }
257
+ }
258
+ }
259
+ syncComplete(model) {
260
+ const count = this.modelsToHistoricSync.get(model) || 0;
261
+ return count === 0;
262
+ }
263
+ async shutdown() {
264
+ if (!this.syncConfig.on)
265
+ return;
266
+ this.subscription?.unsubscribe();
267
+ this.subscription = undefined;
268
+ this.periodicStatusLogger?.unsubscribe();
269
+ this.periodicStatusLogger = undefined;
270
+ await this.jobQueue.stop();
271
+ }
272
+ get enabled() {
273
+ return this.syncConfig.on;
274
+ }
275
+ }
276
+ //# sourceMappingURL=sync-api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync-api.js","sourceRoot":"","sources":["../../src/history-sync/sync-api.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { CID } from 'multiformats/cid';
2
+ import type { IpfsService, TreeMetadata } from './interfaces.js';
3
+ import { PathDirection } from '@ceramicnetwork/anchor-utils';
4
+ export declare class MerkleTreeLoader {
5
+ private readonly ipfsService;
6
+ private readonly rootCid;
7
+ private _metadata;
8
+ constructor(ipfsService: IpfsService, rootCid: CID);
9
+ getMetadata(): Promise<TreeMetadata>;
10
+ getLeafData(index: number): Promise<{
11
+ cid: CID;
12
+ path: PathDirection[];
13
+ }>;
14
+ }
15
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/history-sync/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AACtC,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAChE,OAAO,EAAE,aAAa,EAA2B,MAAM,8BAA8B,CAAA;AAOrF,qBAAa,gBAAgB;IAGf,OAAO,CAAC,QAAQ,CAAC,WAAW;IAAe,OAAO,CAAC,QAAQ,CAAC,OAAO;IAF/E,OAAO,CAAC,SAAS,CAAe;gBAEH,WAAW,EAAE,WAAW,EAAmB,OAAO,EAAE,GAAG;IAM9E,WAAW,IAAI,OAAO,CAAC,YAAY,CAAC;IAapC,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,GAAG,EAAE,GAAG,CAAC;QAAC,IAAI,EAAE,aAAa,EAAE,CAAA;KAAE,CAAC;CAa/E"}
@@ -0,0 +1,23 @@
1
+ import { pathString, pathByIndex } from '@ceramicnetwork/anchor-utils';
2
+ const METADATA_PATH = '2';
3
+ export class MerkleTreeLoader {
4
+ constructor(ipfsService, rootCid) {
5
+ this.ipfsService = ipfsService;
6
+ this.rootCid = rootCid;
7
+ }
8
+ async getMetadata() {
9
+ if (!this._metadata) {
10
+ this._metadata = await this.ipfsService.retrieveFromIPFS(this.rootCid, METADATA_PATH);
11
+ }
12
+ return this._metadata;
13
+ }
14
+ async getLeafData(index) {
15
+ const metadata = await this.getMetadata();
16
+ const path = pathByIndex(index, metadata.numEntries);
17
+ const parent = await this.ipfsService.retrieveFromIPFS(this.rootCid, pathString(path.slice(0, -1)));
18
+ const lastPathDirection = path[path.length - 1];
19
+ const cid = parent[lastPathDirection];
20
+ return { cid, path };
21
+ }
22
+ }
23
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/history-sync/utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAiB,UAAU,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAErF,MAAM,aAAa,GAAG,GAAG,CAAA;AAKzB,MAAM,OAAO,gBAAgB;IAG3B,YAA6B,WAAwB,EAAmB,OAAY;QAAvD,gBAAW,GAAX,WAAW,CAAa;QAAmB,YAAO,GAAP,OAAO,CAAK;IAAG,CAAC;IAMxF,KAAK,CAAC,WAAW;QACf,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;SACtF;QAED,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IAOD,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAA;QACzC,MAAM,IAAI,GAAG,WAAW,CAAC,KAAK,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAA;QAEpD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CACpD,IAAI,CAAC,OAAO,EACZ,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAC9B,CAAA;QACD,MAAM,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAC/C,MAAM,GAAG,GAAG,MAAM,CAAC,iBAAkB,CAAC,CAAA;QAEtC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,CAAA;IACtB,CAAC;CACF"}
@@ -0,0 +1,15 @@
1
+ import { default as PgBoss } from 'pg-boss';
2
+ import type { SendOptions } from 'pg-boss';
3
+ import type { AnchorProof, DiagnosticsLogger } from '@ceramicnetwork/common';
4
+ import { type IpfsService, type HandleCommit, type RebuildAnchorJobData } from '../interfaces.js';
5
+ import type { Worker, Job } from '@ceramicnetwork/job-queue';
6
+ export declare function createRebuildAnchorJob(proof: AnchorProof, models: string[], options?: SendOptions): Job<RebuildAnchorJobData>;
7
+ export declare class RebuildAnchorWorker implements Worker<RebuildAnchorJobData> {
8
+ private readonly ipfsService;
9
+ private readonly handleCommit;
10
+ private readonly logger;
11
+ constructor(ipfsService: IpfsService, handleCommit: HandleCommit, logger: DiagnosticsLogger);
12
+ private getModelForStream;
13
+ handler(job: PgBoss.Job): Promise<void>;
14
+ }
15
+ //# sourceMappingURL=rebuild-anchor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rebuild-anchor.d.ts","sourceRoot":"","sources":["../../../src/history-sync/workers/rebuild-anchor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,SAAS,CAAA;AAC3C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAC1C,OAAO,KAAK,EAAE,WAAW,EAAgB,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAG1F,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,YAAY,EACjB,KAAK,oBAAoB,EAE1B,MAAM,kBAAkB,CAAA;AACzB,OAAO,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,2BAA2B,CAAA;AAgB5D,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,MAAM,EAAE,EAChB,OAAO,GAAE,WAAwC,GAChD,GAAG,CAAC,oBAAoB,CAAC,CAY3B;AAMD,qBAAa,mBAAoB,YAAW,MAAM,CAAC,oBAAoB,CAAC;IAEpE,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFN,WAAW,EAAE,WAAW,EACxB,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,iBAAiB;YAG9B,iBAAiB;IAwBzB,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG;CA4E9B"}
@@ -0,0 +1,96 @@
1
+ import { MerkleTreeLoader } from '../utils.js';
2
+ import { StreamID } from '@ceramicnetwork/streamid';
3
+ import { REBUILD_ANCHOR_JOB, } from '../interfaces.js';
4
+ import { CID } from 'multiformats/cid';
5
+ import { pathString } from '@ceramicnetwork/anchor-utils';
6
+ import PQueue from 'p-queue';
7
+ const IPFS_LOAD_CONCURRENCY = 16;
8
+ const REBUILD_ANCHOR_JOB_OPTIONS = {
9
+ retryLimit: 5,
10
+ retryDelay: 60,
11
+ retryBackoff: true,
12
+ expireInHours: 12,
13
+ retentionDays: 3,
14
+ };
15
+ export function createRebuildAnchorJob(proof, models, options = REBUILD_ANCHOR_JOB_OPTIONS) {
16
+ return {
17
+ name: REBUILD_ANCHOR_JOB,
18
+ data: {
19
+ models,
20
+ chainId: proof.chainId,
21
+ txHash: proof.txHash.toString(),
22
+ root: proof.root.toString(),
23
+ txType: proof.txType,
24
+ },
25
+ options,
26
+ };
27
+ }
28
+ export class RebuildAnchorWorker {
29
+ constructor(ipfsService, handleCommit, logger) {
30
+ this.ipfsService = ipfsService;
31
+ this.handleCommit = handleCommit;
32
+ this.logger = logger;
33
+ }
34
+ async getModelForStream(streamId) {
35
+ const signedCommit = await this.ipfsService.retrieveCommit(streamId.cid, streamId);
36
+ const genesisCommit = signedCommit?.link
37
+ ? await this.ipfsService.retrieveCommit(signedCommit.link, streamId)
38
+ : signedCommit;
39
+ if (!genesisCommit?.header?.model) {
40
+ return null;
41
+ }
42
+ return StreamID.fromBytes(genesisCommit.header.model);
43
+ }
44
+ async handler(job) {
45
+ const jobData = job.data;
46
+ const proof = {
47
+ chainId: jobData.chainId,
48
+ txHash: CID.parse(jobData.txHash),
49
+ root: CID.parse(jobData.root),
50
+ txType: jobData.txType,
51
+ };
52
+ const proofCid = await this.ipfsService.storeRecord(proof).catch((err) => {
53
+ this.logger.err(`Failed to store a proof on ipfs for root ${jobData.root} and txHash ${jobData.txHash} for models ${jobData.models} with error: ${err} `);
54
+ });
55
+ if (!proofCid) {
56
+ return;
57
+ }
58
+ const merkleTreeLeafLoader = new MerkleTreeLoader(this.ipfsService, proof.root);
59
+ const metadata = await merkleTreeLeafLoader.getMetadata().catch((err) => {
60
+ this.logger.err(`Failed to retrieve the merkle tree metadata for root ${jobData.root} and txHash ${jobData.txHash} for models ${jobData.models} with error: ${err} `);
61
+ });
62
+ if (!metadata) {
63
+ return;
64
+ }
65
+ const tasks = metadata.streamIds.map((stream, i) => {
66
+ return async () => {
67
+ try {
68
+ const streamId = StreamID.fromString(stream);
69
+ const model = await this.getModelForStream(streamId);
70
+ const shouldIndex = model
71
+ ? jobData.models.some((modelNeedingSync) => modelNeedingSync === model.toString())
72
+ : false;
73
+ if (shouldIndex) {
74
+ const { cid, path } = await merkleTreeLeafLoader.getLeafData(i);
75
+ const anchorCommit = {
76
+ id: streamId.cid,
77
+ prev: cid,
78
+ proof: proofCid,
79
+ path: pathString(path),
80
+ };
81
+ const anchorCommitCid = await this.ipfsService.storeCommit(anchorCommit);
82
+ await this.handleCommit(streamId, anchorCommitCid, model);
83
+ this.logger.debug(`Successfully handled anchor commit ${anchorCommitCid} for stream ${streamId.toString()} and model ${model.toString()} using merkle tree root ${jobData.root}`);
84
+ }
85
+ }
86
+ catch (err) {
87
+ this.logger.err(`Failed to recreate the anchor commit for stream ${stream} using root ${jobData.root} and txHash ${jobData.txHash} for models ${jobData.models} with error: ${err} `);
88
+ }
89
+ };
90
+ });
91
+ const queue = new PQueue({ concurrency: IPFS_LOAD_CONCURRENCY });
92
+ await queue.addAll(tasks);
93
+ this.logger.debug(`Rebuild anchor job completed for models ${jobData.models}, root ${jobData.root}, and txHash ${jobData.txHash}`);
94
+ }
95
+ }
96
+ //# sourceMappingURL=rebuild-anchor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rebuild-anchor.js","sourceRoot":"","sources":["../../../src/history-sync/workers/rebuild-anchor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import { default as PgBoss } from 'pg-boss';
2
+ import { type SendOptions } from 'pg-boss';
3
+ import { IJobQueue, Job, Worker } from '@ceramicnetwork/job-queue';
4
+ import type { SupportedNetwork } from '@ceramicnetwork/anchor-utils';
5
+ import type { Provider } from '@ethersproject/providers';
6
+ import { JobData, SyncJobType } from '../interfaces.js';
7
+ import { DiagnosticsLogger } from '@ceramicnetwork/common';
8
+ import { SyncJobData } from '../interfaces.js';
9
+ export declare function createContinuousSyncJob(data: SyncJobData, options?: SendOptions): Job<SyncJobData>;
10
+ export declare function createHistorySyncJob(data: SyncJobData, options?: SendOptions): Job<SyncJobData>;
11
+ export interface SyncCompleteData {
12
+ jobType: SyncJobType;
13
+ modelId: string;
14
+ }
15
+ export declare class SyncWorker implements Worker<SyncJobData> {
16
+ private readonly provider;
17
+ private readonly jobQueue;
18
+ private readonly chainId;
19
+ private readonly logger;
20
+ private readonly syncCompleteCallback;
21
+ constructor(provider: Provider, jobQueue: IJobQueue<JobData>, chainId: SupportedNetwork, logger: DiagnosticsLogger, syncCompleteCallback: (data: SyncCompleteData) => void);
22
+ handler(job: PgBoss.Job): Promise<void>;
23
+ }
24
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../../src/history-sync/workers/sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,SAAS,CAAA;AAC3C,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,SAAS,CAAA;AAC1C,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAA;AAElE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AACpE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAGxD,OAAO,EAEL,OAAO,EAGP,WAAW,EACZ,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAU9C,wBAAgB,uBAAuB,CACrC,IAAI,EAAE,WAAW,EACjB,OAAO,CAAC,EAAE,WAAW,GACpB,GAAG,CAAC,WAAW,CAAC,CAMlB;AAED,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,GAAG,CAAC,WAAW,CAAC,CAM/F;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,WAAW,CAAA;IACpB,OAAO,EAAE,MAAM,CAAA;CAChB;AAMD,qBAAa,UAAW,YAAW,MAAM,CAAC,WAAW,CAAC;IAElD,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,oBAAoB;gBAJpB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,SAAS,CAAC,OAAO,CAAC,EAC5B,OAAO,EAAE,gBAAgB,EACzB,MAAM,EAAE,iBAAiB,EACzB,oBAAoB,EAAE,CAAC,IAAI,EAAE,gBAAgB,KAAK,IAAI;IASnE,OAAO,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG;CA8D9B"}