|
| 1 | +import { Block } from "./models/block"; |
| 2 | +import { Log } from "./models/log"; |
| 3 | +import { BlockHistory } from "./models/block-history"; |
| 4 | +import { LogHistory } from "./models/log-history"; |
| 5 | +import { BlockAndLogHistory } from "./models/block-and-log-history"; |
| 6 | +import { Filter, FilterOptions } from "./models/filters"; |
| 7 | +import { reconcileBlockHistory } from "./block-reconciler"; |
| 8 | +import { reconcileLogHistoryWithAddedBlock, reconcileLogHistoryWithRemovedBlock } from "./log-reconciler"; |
| 9 | +import { reconcileBlocksAndLogs } from "./block-and-log-reconciler"; |
| 10 | + |
| 11 | +export function reconcileBlockHistoryWithCallback( |
| 12 | + getBlockByHash: (hash: string, callback: (error?: Error, block?: Block | null) => void) => void, |
| 13 | + blockHistory: BlockHistory | null, |
| 14 | + newBlock: Block, |
| 15 | + onBlockAdded: (block: Block, callback: (error?: Error) => void) => void, |
| 16 | + onBlockRemoved: (block: Block, callback: (error?: Error) => void) => void, |
| 17 | + blockRetention: number, |
| 18 | + callback: (error?: Error, newHistory?: BlockHistory) => void, |
| 19 | +): void { |
| 20 | + const wrappedGetBlockByHash = (hash: string): Promise<Block | null> => new Promise<Block | null>((resolve, reject) => { |
| 21 | + getBlockByHash(hash, (error, block) => { |
| 22 | + if (error) reject(error); |
| 23 | + else resolve(block); |
| 24 | + }); |
| 25 | + }); |
| 26 | + const wrappedOnBlockAdded = (block: Block): Promise<void> => new Promise<void>((resolve, reject) => { |
| 27 | + onBlockAdded(block, (error) => { |
| 28 | + if (error) reject(error); |
| 29 | + else resolve(); |
| 30 | + }); |
| 31 | + }); |
| 32 | + const wrappedOnBlockRemoved = (block: Block): Promise<void> => new Promise<void>((resolve, reject) => { |
| 33 | + onBlockRemoved(block, (error) => { |
| 34 | + if (error) reject(error); |
| 35 | + else resolve(); |
| 36 | + }); |
| 37 | + }); |
| 38 | + reconcileBlockHistory(wrappedGetBlockByHash, blockHistory, newBlock, wrappedOnBlockAdded, wrappedOnBlockRemoved, blockRetention) |
| 39 | + .then(newBlockHistory => callback(undefined, newBlockHistory)) |
| 40 | + .catch(error => callback(error, undefined)); |
| 41 | +} |
| 42 | + |
| 43 | +export function reconcileLogHistoryWithAddedBlockWithCallback( |
| 44 | + getLogs: (filterOptions: FilterOptions[], callback: (error?: Error, logs?: Log[]) => void) => void, |
| 45 | + logHistory: LogHistory | null, |
| 46 | + newBlock: Block, |
| 47 | + onLogAdded: (log: Log, callback: (error?: Error) => void) => void, |
| 48 | + filters: Filter[], |
| 49 | + blockRetention: number, |
| 50 | + callback: (error?: Error, newHistory?: LogHistory) => void, |
| 51 | +): void { |
| 52 | + const wrappedGetLogs = (filterOptions: FilterOptions[]): Promise<Log[]> => new Promise<Log[]>((resolve, reject) => { |
| 53 | + getLogs(filterOptions, (error, logs) => { |
| 54 | + if (error) reject(error); |
| 55 | + else resolve(logs); |
| 56 | + }) |
| 57 | + }); |
| 58 | + const wrappedOnLogAdded = (log: Log): Promise<void> => new Promise<void>((resolve, reject) => { |
| 59 | + onLogAdded(log, error => { |
| 60 | + if (error) reject(error); |
| 61 | + else resolve(); |
| 62 | + }); |
| 63 | + }); |
| 64 | + reconcileLogHistoryWithAddedBlock(wrappedGetLogs, logHistory, newBlock, wrappedOnLogAdded, filters, blockRetention) |
| 65 | + .then(newLogHistory => callback(undefined, newLogHistory)) |
| 66 | + .catch(error => callback(error, undefined)); |
| 67 | +} |
| 68 | + |
| 69 | +export function reconcileLogHistoryWithRemovedBlockWithCallback( |
| 70 | + logHistory: LogHistory, |
| 71 | + removedBlock: Block, |
| 72 | + onLogRemoved: (log: Log, callback: (error?: Error) => void) => void, |
| 73 | + callback: (error?: Error, logHistory?: LogHistory) => void, |
| 74 | +): void { |
| 75 | + const wrappedOnLogRemoved = (log: Log): Promise<void> => new Promise<void>((resolve, reject) => { |
| 76 | + onLogRemoved(log, error => { |
| 77 | + if (error) reject(error); |
| 78 | + else resolve(); |
| 79 | + }); |
| 80 | + }); |
| 81 | + reconcileLogHistoryWithRemovedBlock(logHistory, removedBlock, wrappedOnLogRemoved) |
| 82 | + .then(logHistory => callback(undefined, logHistory)) |
| 83 | + .catch(error => callback(error, undefined)); |
| 84 | +} |
| 85 | + |
| 86 | +export function reconcileBlocksAndLogsWithCallback( |
| 87 | + getBlockByHash: (hash: string, callback: (error?: Error, block?: Block | null) => void) => void, |
| 88 | + getLogs: (filterOptions: FilterOptions[], callback: (error?: Error, logs?: Log[]) => void) => void, |
| 89 | + history: BlockAndLogHistory | null, |
| 90 | + newBlock: Block, |
| 91 | + onLogAdded: (log: Log, callback: (error?: Error) => void) => void, |
| 92 | + onLogRemoved: (log: Log, callback: (error?: Error) => void) => void, |
| 93 | + filters: Filter[], |
| 94 | + blockRetention: number, |
| 95 | + callback: (error?: Error, newHistory?: BlockAndLogHistory) => void, |
| 96 | +): void { |
| 97 | + const wrappedGetBlockByHash = (hash: string): Promise<Block | null> => new Promise<Block | null>((resolve, reject) => { |
| 98 | + getBlockByHash(hash, (error, block) => { |
| 99 | + if (error) reject(error); |
| 100 | + else resolve(block); |
| 101 | + }); |
| 102 | + }); |
| 103 | + const wrappedGetLogs = (filterOptions: FilterOptions[]): Promise<Log[]> => new Promise<Log[]>((resolve, reject) => { |
| 104 | + getLogs(filterOptions, (error, logs) => { |
| 105 | + if (error) reject(error); |
| 106 | + else resolve(logs); |
| 107 | + }) |
| 108 | + }); |
| 109 | + const wrappedOnLogAdded = (log: Log): Promise<void> => new Promise<void>((resolve, reject) => { |
| 110 | + onLogAdded(log, error => { |
| 111 | + if (error) reject(error); |
| 112 | + else resolve(); |
| 113 | + }); |
| 114 | + }); |
| 115 | + const wrappedOnLogRemoved = (log: Log): Promise<void> => new Promise<void>((resolve, reject) => { |
| 116 | + onLogRemoved(log, error => { |
| 117 | + if (error) reject(error); |
| 118 | + else resolve(); |
| 119 | + }); |
| 120 | + }); |
| 121 | + reconcileBlocksAndLogs(wrappedGetBlockByHash, wrappedGetLogs, history, newBlock, wrappedOnLogAdded, wrappedOnLogRemoved, filters, blockRetention) |
| 122 | + .then(blockAndLogHistory => callback(undefined, blockAndLogHistory)) |
| 123 | + .catch(error => callback(error, undefined)); |
| 124 | +} |
0 commit comments