@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.
- package/README.md +31 -0
- package/lib/__tests__/chunks.util.d.ts +2 -0
- package/lib/__tests__/chunks.util.d.ts.map +1 -0
- package/lib/__tests__/chunks.util.js +8 -0
- package/lib/__tests__/chunks.util.js.map +1 -0
- package/lib/__tests__/read-csv-fixture.util.d.ts +5 -0
- package/lib/__tests__/read-csv-fixture.util.d.ts.map +1 -0
- package/lib/__tests__/read-csv-fixture.util.js +35 -0
- package/lib/__tests__/read-csv-fixture.util.js.map +1 -0
- package/lib/as-table-name.util.d.ts +3 -0
- package/lib/as-table-name.util.d.ts.map +1 -0
- package/lib/as-table-name.util.js +4 -0
- package/lib/as-table-name.util.js.map +1 -0
- package/lib/build-indexing.d.ts +13 -0
- package/lib/build-indexing.d.ts.map +1 -0
- package/lib/build-indexing.js +55 -0
- package/lib/build-indexing.js.map +1 -0
- package/lib/column-name.util.d.ts +2 -0
- package/lib/column-name.util.d.ts.map +1 -0
- package/lib/column-name.util.js +5 -0
- package/lib/column-name.util.js.map +1 -0
- package/lib/config.d.ts +2 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +2 -0
- package/lib/config.js.map +1 -0
- package/lib/database-index-api.d.ts +94 -0
- package/lib/database-index-api.d.ts.map +1 -0
- package/lib/database-index-api.js +228 -0
- package/lib/database-index-api.js.map +1 -0
- package/lib/history-sync/interfaces.d.ts +52 -0
- package/lib/history-sync/interfaces.d.ts.map +1 -0
- package/lib/history-sync/interfaces.js +11 -0
- package/lib/history-sync/interfaces.js.map +1 -0
- package/lib/history-sync/sync-api.d.ts +82 -0
- package/lib/history-sync/sync-api.d.ts.map +1 -0
- package/lib/history-sync/sync-api.js +276 -0
- package/lib/history-sync/sync-api.js.map +1 -0
- package/lib/history-sync/utils.d.ts +15 -0
- package/lib/history-sync/utils.d.ts.map +1 -0
- package/lib/history-sync/utils.js +23 -0
- package/lib/history-sync/utils.js.map +1 -0
- package/lib/history-sync/workers/rebuild-anchor.d.ts +15 -0
- package/lib/history-sync/workers/rebuild-anchor.d.ts.map +1 -0
- package/lib/history-sync/workers/rebuild-anchor.js +96 -0
- package/lib/history-sync/workers/rebuild-anchor.js.map +1 -0
- package/lib/history-sync/workers/sync.d.ts +24 -0
- package/lib/history-sync/workers/sync.d.ts.map +1 -0
- package/lib/history-sync/workers/sync.js +77 -0
- package/lib/history-sync/workers/sync.js.map +1 -0
- package/lib/index-query-not-available.error.d.ts +5 -0
- package/lib/index-query-not-available.error.d.ts.map +1 -0
- package/lib/index-query-not-available.error.js +6 -0
- package/lib/index-query-not-available.error.js.map +1 -0
- package/lib/index.d.ts +7 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +6 -0
- package/lib/index.js.map +1 -0
- package/lib/insertion-order.d.ts +15 -0
- package/lib/insertion-order.d.ts.map +1 -0
- package/lib/insertion-order.js +180 -0
- package/lib/insertion-order.js.map +1 -0
- package/lib/local-index-api.d.ts +30 -0
- package/lib/local-index-api.d.ts.map +1 -0
- package/lib/local-index-api.js +118 -0
- package/lib/local-index-api.js.map +1 -0
- package/lib/make-index-api.d.ts +9 -0
- package/lib/make-index-api.d.ts.map +1 -0
- package/lib/make-index-api.js +27 -0
- package/lib/make-index-api.js.map +1 -0
- package/lib/migrations/1-create-model-table.d.ts +34 -0
- package/lib/migrations/1-create-model-table.d.ts.map +1 -0
- package/lib/migrations/1-create-model-table.js +243 -0
- package/lib/migrations/1-create-model-table.js.map +1 -0
- package/lib/migrations/cdb-schema-verification.d.ts +15 -0
- package/lib/migrations/cdb-schema-verification.d.ts.map +1 -0
- package/lib/migrations/cdb-schema-verification.js +272 -0
- package/lib/migrations/cdb-schema-verification.js.map +1 -0
- package/lib/parse-pagination.d.ts +18 -0
- package/lib/parse-pagination.d.ts.map +1 -0
- package/lib/parse-pagination.js +23 -0
- package/lib/parse-pagination.js.map +1 -0
- package/lib/query-filter-converter.d.ts +12 -0
- package/lib/query-filter-converter.d.ts.map +1 -0
- package/lib/query-filter-converter.js +231 -0
- package/lib/query-filter-converter.js.map +1 -0
- package/lib/query-filter-parser.d.ts +63 -0
- package/lib/query-filter-parser.d.ts.map +1 -0
- package/lib/query-filter-parser.js +178 -0
- package/lib/query-filter-parser.js.map +1 -0
- package/lib/tables-manager.d.ts +44 -0
- package/lib/tables-manager.d.ts.map +1 -0
- package/lib/tables-manager.js +218 -0
- package/lib/tables-manager.js.map +1 -0
- package/lib/unsupported-ordering-error.d.ts +4 -0
- package/lib/unsupported-ordering-error.d.ts.map +1 -0
- package/lib/unsupported-ordering-error.js +6 -0
- package/lib/unsupported-ordering-error.js.map +1 -0
- 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"}
|