@xyo-network/chain-wrappers 1.18.5 → 1.19.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.
@@ -1,13 +1,14 @@
1
1
  import type { Hash, Hex } from '@xylabs/sdk-js';
2
2
  import type { WithHashMeta } from '@xyo-network/payload-model';
3
- import type { AccountBalanceViewer, HydratedBlockInstance, HydratedBlockWithHashMeta, HydratedTransactionInstance, SignatureInstance } from '@xyo-network/xl1-sdk';
3
+ import type { AccountBalanceViewer, BaseContext, HydratedBlockInstance, HydratedBlockWithHashMeta, HydratedTransactionInstance, SignatureInstance } from '@xyo-network/xl1-sdk';
4
4
  export declare class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implements HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]> {
5
5
  data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]];
6
6
  protected allPayloadsCache: WithHashMeta<T[1][number]>[];
7
+ protected context: BaseContext;
7
8
  protected transactionsCache: HydratedTransactionInstance[];
8
9
  private _parseErrors;
9
10
  private _signatureCache;
10
- protected constructor(data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]);
11
+ protected constructor(context: BaseContext, data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]);
11
12
  get block(): import("@xyo-network/xl1-sdk").XL1BlockNumber;
12
13
  get boundWitness(): WithHashMeta<T[0]>;
13
14
  get chain(): Hex;
@@ -20,7 +21,7 @@ export declare class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> i
20
21
  get stepHashes(): Hash[];
21
22
  get transactionCount(): number;
22
23
  get transactions(): HydratedTransactionInstance[];
23
- static parse<T extends HydratedBlockWithHashMeta>(block: T, validate?: boolean): Promise<HydratedBlockInstance>;
24
+ static parse<T extends HydratedBlockWithHashMeta>(context: BaseContext, block: T, validate?: boolean): Promise<HydratedBlockInstance>;
24
25
  payload(index: number): WithHashMeta<T[1][number]> | undefined;
25
26
  signature(index: number): SignatureInstance | undefined;
26
27
  transaction(index: number): HydratedTransactionInstance | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"HydratedBlock.d.ts","sourceRoot":"","sources":["../../../src/block/HydratedBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAI/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EACV,oBAAoB,EACpB,qBAAqB,EAAE,yBAAyB,EAAE,2BAA2B,EAAE,iBAAiB,EAEjG,MAAM,sBAAsB,CAAA;AAe7B,qBAAa,oBAAoB,CAAC,CAAC,SAAS,yBAAyB,CAAE,YAAW,qBAAqB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC;IACzJ,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAA;IACxD,SAAS,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAK;IAC7D,SAAS,CAAC,iBAAiB,EAAE,2BAA2B,EAAE,CAAK;IAC/D,OAAO,CAAC,YAAY,CAAc;IAClC,OAAO,CAAC,eAAe,CAA0B;IAEjD,SAAS,aAAa,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;IAI9E,IAAI,KAAK,kDAER;IAED,IAAI,YAAY,uBAEf;IAED,IAAI,KAAK,IAAI,GAAG,CAEf;IAED,IAAI,WAAW,YAEd;IAED,IAAI,YAAY,IAAI,MAAM,CAEzB;IAED,IAAI,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAE7B;IAED,IAAI,MAAM,IAAI,MAAM,CAOnB;IAED,IAAI,cAAc,IAAI,MAAM,CAE3B;IAED,IAAI,UAAU,IAAI,iBAAiB,EAAE,CAEpC;IAED,IAAI,UAAU,IAAI,IAAI,EAAE,CAEvB;IAED,IAAI,gBAAgB,IAAI,MAAM,CAE7B;IAED,IAAI,YAAY,IAAI,2BAA2B,EAAE,CAEhD;WAEY,KAAK,CAAC,CAAC,SAAS,yBAAyB,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,UAAQ,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAKnH,OAAO,CAAC,KAAK,EAAE,MAAM;IAIrB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS;IAIvD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,2BAA2B,GAAG,SAAS;IAI7D,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAI5B,aAAa,CAAC,QAAQ,EAAE;QAAE,cAAc,EAAE,oBAAoB,CAAA;KAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;cAIzE,KAAK,CAAC,QAAQ,UAAQ,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAkB5H"}
1
+ {"version":3,"file":"HydratedBlock.d.ts","sourceRoot":"","sources":["../../../src/block/HydratedBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAI/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,KAAK,EACV,oBAAoB,EACpB,WAAW,EACX,qBAAqB,EAAE,yBAAyB,EAAE,2BAA2B,EAAE,iBAAiB,EAEjG,MAAM,sBAAsB,CAAA;AAe7B,qBAAa,oBAAoB,CAAC,CAAC,SAAS,yBAAyB,CAAE,YAAW,qBAAqB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC;IACzJ,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAA;IACxD,SAAS,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAK;IAC7D,SAAS,CAAC,OAAO,EAAE,WAAW,CAAA;IAC9B,SAAS,CAAC,iBAAiB,EAAE,2BAA2B,EAAE,CAAK;IAC/D,OAAO,CAAC,YAAY,CAAc;IAClC,OAAO,CAAC,eAAe,CAA0B;IAEjD,SAAS,aAAa,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;IAKpG,IAAI,KAAK,kDAER;IAED,IAAI,YAAY,uBAEf;IAED,IAAI,KAAK,IAAI,GAAG,CAEf;IAED,IAAI,WAAW,YAEd;IAED,IAAI,YAAY,IAAI,MAAM,CAEzB;IAED,IAAI,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAE7B;IAED,IAAI,MAAM,IAAI,MAAM,CAOnB;IAED,IAAI,cAAc,IAAI,MAAM,CAE3B;IAED,IAAI,UAAU,IAAI,iBAAiB,EAAE,CAEpC;IAED,IAAI,UAAU,IAAI,IAAI,EAAE,CAEvB;IAED,IAAI,gBAAgB,IAAI,MAAM,CAE7B;IAED,IAAI,YAAY,IAAI,2BAA2B,EAAE,CAEhD;WAEY,KAAK,CAAC,CAAC,SAAS,yBAAyB,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,UAAQ,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAKzI,OAAO,CAAC,KAAK,EAAE,MAAM;IAIrB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS;IAIvD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,2BAA2B,GAAG,SAAS;IAI7D,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAI5B,aAAa,CAAC,QAAQ,EAAE;QAAE,cAAc,EAAE,oBAAoB,CAAA;KAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;cAIzE,KAAK,CAAC,QAAQ,UAAQ,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;CAkB5H"}
@@ -19,11 +19,13 @@ var HydratedBlockWrapper = class _HydratedBlockWrapper {
19
19
  }
20
20
  data;
21
21
  allPayloadsCache = [];
22
+ context;
22
23
  transactionsCache = [];
23
24
  _parseErrors = [];
24
25
  _signatureCache = [];
25
- constructor(data) {
26
+ constructor(context, data) {
26
27
  this.data = data;
28
+ this.context = context;
27
29
  }
28
30
  get block() {
29
31
  return this.data[0].block;
@@ -65,8 +67,8 @@ var HydratedBlockWrapper = class _HydratedBlockWrapper {
65
67
  get transactions() {
66
68
  return this.transactionsCache;
67
69
  }
68
- static async parse(block, validate = false) {
69
- const wrapper = new _HydratedBlockWrapper(block);
70
+ static async parse(context, block, validate = false) {
71
+ const wrapper = new _HydratedBlockWrapper(context, block);
70
72
  return await wrapper.parse(validate);
71
73
  }
72
74
  payload(index) {
@@ -79,10 +81,10 @@ var HydratedBlockWrapper = class _HydratedBlockWrapper {
79
81
  return this.transactionsCache.at(index);
80
82
  }
81
83
  async validate() {
82
- return await validateHydratedBlock(this.data);
84
+ return await validateHydratedBlock(this.context, this.data);
83
85
  }
84
86
  async validateState(services) {
85
- return await validateHydratedBlockState(this.data, () => this.chain, services);
87
+ return await validateHydratedBlockState(this.context, this.data, () => this.chain, services);
86
88
  }
87
89
  async parse(validate = false) {
88
90
  const allPayloads = await PayloadBuilder.addStorageMeta(this.data[1]);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/block/HydratedBlock.ts","../../src/block/IndexedHydratedBlockRangeStore.ts","../../src/index.ts"],"sourcesContent":["import type { Hash, Hex } from '@xylabs/sdk-js'\nimport { hexToBigInt } from '@xylabs/sdk-js'\nimport { validateHydratedBlock, validateHydratedBlockState } from '@xyo-network/chain-validation'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithHashMeta } from '@xyo-network/payload-model'\nimport type {\n AccountBalanceViewer,\n HydratedBlockInstance, HydratedBlockWithHashMeta, HydratedTransactionInstance, SignatureInstance,\n SignedHydratedTransactionWithStorageMeta, Transfer,\n} from '@xyo-network/xl1-sdk'\nimport {\n createSignatureWrappers, HydratedTransactionWrapper,\n isSignedTransactionBoundWitnessWithStorageMeta,\n isTransfer, XYO_ZERO_ADDRESS,\n} from '@xyo-network/xl1-sdk'\n\nconst sumTransfers = (payload: Transfer) => {\n let total = 0n\n for (let i of Object.values(payload.transfers)) {\n total += hexToBigInt(i ?? '00' as Hex)\n }\n return total\n}\n\nexport class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implements HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]> {\n data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]\n protected allPayloadsCache: WithHashMeta<T[1][number]>[] = []\n protected transactionsCache: HydratedTransactionInstance[] = []\n private _parseErrors: Error[] = []\n private _signatureCache: SignatureInstance[] = []\n\n protected constructor(data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]) {\n this.data = data\n }\n\n get block() {\n return this.data[0].block\n }\n\n get boundWitness() {\n return this.data[0]\n }\n\n get chain(): Hex {\n return this.data[0].chain\n }\n\n get parseErrors() {\n return this._parseErrors\n }\n\n get payloadCount(): number {\n return this.allPayloadsCache.length\n }\n\n get payloads(): T[1][number][] {\n return [...this.allPayloadsCache]\n }\n\n get reward(): bigint {\n return this.allPayloadsCache.reduce((acc: bigint, payload) => acc + (\n isTransfer(payload)\n ? payload.from === XYO_ZERO_ADDRESS\n ? sumTransfers(payload)\n : 0n\n : 0n), 0n)\n }\n\n get signatureCount(): number {\n return this._signatureCache.length\n }\n\n get signatures(): SignatureInstance[] {\n return [...this._signatureCache]\n }\n\n get stepHashes(): Hash[] {\n return this.data[0].step_hashes ?? []\n }\n\n get transactionCount(): number {\n return this.transactionsCache.length\n }\n\n get transactions(): HydratedTransactionInstance[] {\n return this.transactionsCache\n }\n\n static async parse<T extends HydratedBlockWithHashMeta>(block: T, validate = false): Promise<HydratedBlockInstance> {\n const wrapper = new HydratedBlockWrapper(block)\n return await wrapper.parse(validate)\n }\n\n payload(index: number) {\n return this.data[1].at(index)\n }\n\n signature(index: number): SignatureInstance | undefined {\n return this._signatureCache[index]\n }\n\n transaction(index: number): HydratedTransactionInstance | undefined {\n return this.transactionsCache.at(index)\n }\n\n async validate(): Promise<Error[]> {\n return await validateHydratedBlock(this.data)\n }\n\n async validateState(services: { accountBalance: AccountBalanceViewer }): Promise<Error[]> {\n return await validateHydratedBlockState(this.data, () => this.chain, services)\n }\n\n protected async parse(validate = false): Promise<HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]>> {\n const allPayloads = await PayloadBuilder.addStorageMeta(this.data[1])\n for (const payload of allPayloads) {\n if (isSignedTransactionBoundWitnessWithStorageMeta(payload)) {\n const hydratedTransaction: SignedHydratedTransactionWithStorageMeta = [payload, allPayloads.filter(\n p => payload.payload_hashes.includes(p._hash) || payload.payload_hashes.includes(p._dataHash),\n )]\n this.transactionsCache.push(await HydratedTransactionWrapper.parse(hydratedTransaction))\n } else {\n this.allPayloadsCache.push(payload)\n }\n }\n this._signatureCache = await createSignatureWrappers(this.data[0])\n if (validate) {\n this._parseErrors = await this.validate()\n }\n return this\n }\n}\n","import type {\n BaseParams, EmptyObject, Hash, Promisable,\n} from '@xylabs/sdk-js'\nimport {\n assertEx, BaseEmitter, exists, isDefined,\n} from '@xylabs/sdk-js'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport {\n asBlockBoundWitness, asBlockBoundWitnessWithStorageMeta, type BlockWindowInstance, hydrateBlock, type HydratedBlock,\n readPayloadMapFromStore,\n} from '@xyo-network/xl1-sdk'\nimport { Semaphore } from 'async-mutex'\n\nexport type HydratedBlockStoreParams<TAdditionalParams extends EmptyObject = EmptyObject> = BaseParams<{\n sourceArchivist: ArchivistInstance\n} & TAdditionalParams>\n\nexport interface HydratedBlockStoreInstance {\n fromHash(hash: Hash): Promisable<HydratedBlock | undefined>\n}\n\nexport interface IndexedHydratedBlockStoreInstance extends HydratedBlockStoreInstance {\n fromNumber(number: number): Promisable<HydratedBlock | undefined>\n}\n\nexport interface HydratedBlockRangeStoreParams extends HydratedBlockStoreParams<{\n first: Hash\n last: Hash\n snapshotArchivist: ArchivistInstance\n}> {}\n\nexport interface IndexedHydratedBlockRangeStoreInstance extends BlockWindowInstance, IndexedHydratedBlockStoreInstance {\n first(): Promisable<HydratedBlock>\n last(): Promisable<HydratedBlock>\n next(from: HydratedBlock): Promisable<HydratedBlock | undefined>\n next(from: HydratedBlock, count: number): Promisable<HydratedBlock[]>\n prev(from: HydratedBlock): Promisable<HydratedBlock | undefined>\n prev(from: HydratedBlock, count: number): Promisable<HydratedBlock[]>\n}\n\nconst BlockNumberIndexSemaphoreLocks = 10 as const\n\n// TODO: Allow/Require source/snapshot archivist to be BlockStores instead\nexport class IndexedHydratedBlockRangeStore extends BaseEmitter<HydratedBlockRangeStoreParams> implements IndexedHydratedBlockRangeStoreInstance {\n private _blockNumberIndex: Map<number, Hash> = new Map()\n private _blockNumberIndexSemaphore = new Semaphore(BlockNumberIndexSemaphoreLocks)\n private _firstNumber: number\n private _lastNumber: number\n\n protected constructor(params: HydratedBlockRangeStoreParams, firstNumber: number, lastNumber: number) {\n super(params)\n this._firstNumber = firstNumber\n this._lastNumber = lastNumber\n }\n\n get count(): number {\n return this._lastNumber - this._firstNumber + 1\n }\n\n get numberRange(): [number, number] {\n return [this._firstNumber, this._lastNumber]\n }\n\n get range(): [Hash, Hash] {\n return [this.params.first, this.params.last]\n }\n\n static async create(params: HydratedBlockRangeStoreParams): Promise<IndexedHydratedBlockRangeStore> {\n const firstBlock = asBlockBoundWitness((await params.sourceArchivist.get([params.first])).at(0)\n ?? (await params.snapshotArchivist.get([params.first])).at(0))\n const firstBlockExisting = assertEx(firstBlock, () => 'First block not found')\n\n const lastBlock = asBlockBoundWitness((await params.sourceArchivist.get([params.last])).at(0)\n ?? (await params.snapshotArchivist.get([params.last])).at(0))\n const lastBlockExisting = assertEx(lastBlock, () => 'Last block not found')\n\n // getting the block numbers here since can not get them in the constructor\n const result = new IndexedHydratedBlockRangeStore(params, firstBlockExisting.block, lastBlockExisting.block)\n result.createSubscriptions()\n await result.index()\n return result\n }\n\n async first(): Promise<HydratedBlock> {\n return assertEx(await this.fromHash(this.params.first), () => 'First block not found')\n }\n\n async fromHash(hash: Hash): Promise<HydratedBlock | undefined> {\n const chainMap = readPayloadMapFromStore<WithStorageMeta<Payload>>(this.params.sourceArchivist)\n const snapshotMap = readPayloadMapFromStore<WithStorageMeta<Payload>>(this.params.snapshotArchivist)\n const block = (await hydrateBlock({ chainMap }, hash))\n ?? (await hydrateBlock({ chainMap: snapshotMap }, hash))\n if (isDefined(block) && (block[0].block <= this._lastNumber && block[0].block >= this._firstNumber)) {\n return block\n }\n }\n\n fromNumber(number: number): Promisable<HydratedBlock | undefined> {\n const hash = this._blockNumberIndex.get(number)\n if (isDefined(hash)) {\n return this.fromHash(hash)\n }\n }\n\n async last(): Promise<HydratedBlock> {\n return assertEx(await this.fromHash(this.params.last), () => 'Last block not found')\n }\n\n async next(from: HydratedBlock): Promise<HydratedBlock | undefined>\n async next(from: HydratedBlock, count: number): Promise<HydratedBlock[]>\n async next(from: HydratedBlock, count?: number): Promise<HydratedBlock | HydratedBlock[] | undefined> {\n const nextBlockNumber = from[0].block + 1\n if (nextBlockNumber > this._lastNumber) {\n return isDefined(count) ? [] : undefined\n }\n if (isDefined(count)) {\n if (count === 0) {\n return []\n }\n const nextBlock = await this.fromNumber(nextBlockNumber)\n\n if (isDefined(nextBlock)) {\n return [nextBlock, ...await this.next(nextBlock, count - 1)].filter(exists)\n } else {\n if (from[0].block < this._lastNumber) {\n throw new Error(`Next block [${nextBlockNumber}] not found, but should be in range`)\n }\n return []\n }\n } else {\n return await this.fromNumber(nextBlockNumber)\n }\n }\n\n async prev(from: HydratedBlock): Promise<HydratedBlock | undefined>\n async prev(from: HydratedBlock, count: number): Promise<HydratedBlock[]>\n async prev(from: HydratedBlock, count?: number): Promise<HydratedBlock | HydratedBlock[] | undefined> {\n const prevBlockNumber = from[0].block - 1\n if (prevBlockNumber < this._firstNumber) {\n return isDefined(count) ? [] : undefined\n }\n if (isDefined(count)) {\n if (count === 0) {\n return []\n }\n const prevBlock = await this.fromNumber(prevBlockNumber)\n if (isDefined(prevBlock)) {\n return [...await this.next(prevBlock, count - 1), prevBlock].filter(exists)\n } else {\n if (from[0].block > this._firstNumber) {\n throw new Error(`Prev block [${prevBlockNumber}] not found, but should be in range`)\n }\n return []\n }\n } else {\n return await this.fromNumber(prevBlockNumber)\n }\n }\n\n private createSubscriptions(): void {\n // we monitor deletes so that we can keep them if we need them for the window\n this.params.sourceArchivist.on('deleted', async ({ payloads }) => {\n await this.params.snapshotArchivist.insert(payloads)\n })\n }\n\n private async index() {\n // get all the locks (make exclusive)\n await this._blockNumberIndexSemaphore.acquire(BlockNumberIndexSemaphoreLocks)\n try {\n this._blockNumberIndex.clear()\n let blockToIndex: Hash = this.params.last\n let firstFound = false\n while (!firstFound) {\n const payload = assertEx((await this.params.sourceArchivist.get([blockToIndex])).at(0), () => 'Block payload not found')\n const block = assertEx(asBlockBoundWitnessWithStorageMeta(payload), () => 'Payload is not a Block')\n if (block.block < this._firstNumber || block.block > this._lastNumber) {\n throw new Error(`Block [${block.block}] is out of range`)\n }\n this._blockNumberIndex.set(block.block, block._hash)\n firstFound = block.block === this._firstNumber\n }\n } finally {\n this._blockNumberIndexSemaphore.release(BlockNumberIndexSemaphoreLocks)\n }\n }\n}\n","export * from './block/index.ts'\nexport * from '@xyo-network/xl1-sdk'\n"],"mappings":"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","names":["hexToBigInt","validateHydratedBlock","validateHydratedBlockState","PayloadBuilder","createSignatureWrappers","HydratedTransactionWrapper","isSignedTransactionBoundWitnessWithStorageMeta","isTransfer","XYO_ZERO_ADDRESS","sumTransfers","payload","total","i","Object","values","transfers","hexToBigInt","HydratedBlockWrapper","data","allPayloadsCache","transactionsCache","_parseErrors","_signatureCache","block","boundWitness","chain","parseErrors","payloadCount","length","payloads","reward","reduce","acc","isTransfer","from","XYO_ZERO_ADDRESS","signatureCount","signatures","stepHashes","step_hashes","transactionCount","transactions","parse","validate","wrapper","index","at","signature","transaction","validateHydratedBlock","validateState","services","validateHydratedBlockState","allPayloads","PayloadBuilder","addStorageMeta","isSignedTransactionBoundWitnessWithStorageMeta","hydratedTransaction","filter","p","payload_hashes","includes","_hash","_dataHash","push","HydratedTransactionWrapper","createSignatureWrappers","assertEx","BaseEmitter","exists","isDefined","asBlockBoundWitness","asBlockBoundWitnessWithStorageMeta","hydrateBlock","readPayloadMapFromStore","Semaphore","BlockNumberIndexSemaphoreLocks","IndexedHydratedBlockRangeStore","BaseEmitter","_blockNumberIndex","Map","_blockNumberIndexSemaphore","Semaphore","_firstNumber","_lastNumber","params","firstNumber","lastNumber","count","numberRange","range","first","last","create","firstBlock","asBlockBoundWitness","sourceArchivist","get","at","snapshotArchivist","firstBlockExisting","assertEx","lastBlock","lastBlockExisting","result","block","createSubscriptions","index","fromHash","hash","chainMap","readPayloadMapFromStore","snapshotMap","hydrateBlock","isDefined","fromNumber","number","next","from","nextBlockNumber","undefined","nextBlock","filter","exists","Error","prev","prevBlockNumber","prevBlock","on","payloads","insert","acquire","clear","blockToIndex","firstFound","payload","asBlockBoundWitnessWithStorageMeta","set","_hash","release"]}
1
+ {"version":3,"sources":["../../src/block/HydratedBlock.ts","../../src/block/IndexedHydratedBlockRangeStore.ts","../../src/index.ts"],"sourcesContent":["import type { Hash, Hex } from '@xylabs/sdk-js'\nimport { hexToBigInt } from '@xylabs/sdk-js'\nimport { validateHydratedBlock, validateHydratedBlockState } from '@xyo-network/chain-validation'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithHashMeta } from '@xyo-network/payload-model'\nimport type {\n AccountBalanceViewer,\n BaseContext,\n HydratedBlockInstance, HydratedBlockWithHashMeta, HydratedTransactionInstance, SignatureInstance,\n SignedHydratedTransactionWithStorageMeta, Transfer,\n} from '@xyo-network/xl1-sdk'\nimport {\n createSignatureWrappers, HydratedTransactionWrapper,\n isSignedTransactionBoundWitnessWithStorageMeta,\n isTransfer, XYO_ZERO_ADDRESS,\n} from '@xyo-network/xl1-sdk'\n\nconst sumTransfers = (payload: Transfer) => {\n let total = 0n\n for (let i of Object.values(payload.transfers)) {\n total += hexToBigInt(i ?? '00' as Hex)\n }\n return total\n}\n\nexport class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implements HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]> {\n data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]\n protected allPayloadsCache: WithHashMeta<T[1][number]>[] = []\n protected context: BaseContext\n protected transactionsCache: HydratedTransactionInstance[] = []\n private _parseErrors: Error[] = []\n private _signatureCache: SignatureInstance[] = []\n\n protected constructor(context: BaseContext, data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]) {\n this.data = data\n this.context = context\n }\n\n get block() {\n return this.data[0].block\n }\n\n get boundWitness() {\n return this.data[0]\n }\n\n get chain(): Hex {\n return this.data[0].chain\n }\n\n get parseErrors() {\n return this._parseErrors\n }\n\n get payloadCount(): number {\n return this.allPayloadsCache.length\n }\n\n get payloads(): T[1][number][] {\n return [...this.allPayloadsCache]\n }\n\n get reward(): bigint {\n return this.allPayloadsCache.reduce((acc: bigint, payload) => acc + (\n isTransfer(payload)\n ? payload.from === XYO_ZERO_ADDRESS\n ? sumTransfers(payload)\n : 0n\n : 0n), 0n)\n }\n\n get signatureCount(): number {\n return this._signatureCache.length\n }\n\n get signatures(): SignatureInstance[] {\n return [...this._signatureCache]\n }\n\n get stepHashes(): Hash[] {\n return this.data[0].step_hashes ?? []\n }\n\n get transactionCount(): number {\n return this.transactionsCache.length\n }\n\n get transactions(): HydratedTransactionInstance[] {\n return this.transactionsCache\n }\n\n static async parse<T extends HydratedBlockWithHashMeta>(context: BaseContext, block: T, validate = false): Promise<HydratedBlockInstance> {\n const wrapper = new HydratedBlockWrapper(context, block)\n return await wrapper.parse(validate)\n }\n\n payload(index: number) {\n return this.data[1].at(index)\n }\n\n signature(index: number): SignatureInstance | undefined {\n return this._signatureCache[index]\n }\n\n transaction(index: number): HydratedTransactionInstance | undefined {\n return this.transactionsCache.at(index)\n }\n\n async validate(): Promise<Error[]> {\n return await validateHydratedBlock(this.context, this.data)\n }\n\n async validateState(services: { accountBalance: AccountBalanceViewer }): Promise<Error[]> {\n return await validateHydratedBlockState(this.context, this.data, () => this.chain, services)\n }\n\n protected async parse(validate = false): Promise<HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]>> {\n const allPayloads = await PayloadBuilder.addStorageMeta(this.data[1])\n for (const payload of allPayloads) {\n if (isSignedTransactionBoundWitnessWithStorageMeta(payload)) {\n const hydratedTransaction: SignedHydratedTransactionWithStorageMeta = [payload, allPayloads.filter(\n p => payload.payload_hashes.includes(p._hash) || payload.payload_hashes.includes(p._dataHash),\n )]\n this.transactionsCache.push(await HydratedTransactionWrapper.parse(hydratedTransaction))\n } else {\n this.allPayloadsCache.push(payload)\n }\n }\n this._signatureCache = await createSignatureWrappers(this.data[0])\n if (validate) {\n this._parseErrors = await this.validate()\n }\n return this\n }\n}\n","import type {\n BaseParams, EmptyObject, Hash, Promisable,\n} from '@xylabs/sdk-js'\nimport {\n assertEx, BaseEmitter, exists, isDefined,\n} from '@xylabs/sdk-js'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport {\n asBlockBoundWitness, asBlockBoundWitnessWithStorageMeta, type BlockWindowInstance, hydrateBlock, type HydratedBlock,\n readPayloadMapFromStore,\n} from '@xyo-network/xl1-sdk'\nimport { Semaphore } from 'async-mutex'\n\nexport type HydratedBlockStoreParams<TAdditionalParams extends EmptyObject = EmptyObject> = BaseParams<{\n sourceArchivist: ArchivistInstance\n} & TAdditionalParams>\n\nexport interface HydratedBlockStoreInstance {\n fromHash(hash: Hash): Promisable<HydratedBlock | undefined>\n}\n\nexport interface IndexedHydratedBlockStoreInstance extends HydratedBlockStoreInstance {\n fromNumber(number: number): Promisable<HydratedBlock | undefined>\n}\n\nexport interface HydratedBlockRangeStoreParams extends HydratedBlockStoreParams<{\n first: Hash\n last: Hash\n snapshotArchivist: ArchivistInstance\n}> {}\n\nexport interface IndexedHydratedBlockRangeStoreInstance extends BlockWindowInstance, IndexedHydratedBlockStoreInstance {\n first(): Promisable<HydratedBlock>\n last(): Promisable<HydratedBlock>\n next(from: HydratedBlock): Promisable<HydratedBlock | undefined>\n next(from: HydratedBlock, count: number): Promisable<HydratedBlock[]>\n prev(from: HydratedBlock): Promisable<HydratedBlock | undefined>\n prev(from: HydratedBlock, count: number): Promisable<HydratedBlock[]>\n}\n\nconst BlockNumberIndexSemaphoreLocks = 10 as const\n\n// TODO: Allow/Require source/snapshot archivist to be BlockStores instead\nexport class IndexedHydratedBlockRangeStore extends BaseEmitter<HydratedBlockRangeStoreParams> implements IndexedHydratedBlockRangeStoreInstance {\n private _blockNumberIndex: Map<number, Hash> = new Map()\n private _blockNumberIndexSemaphore = new Semaphore(BlockNumberIndexSemaphoreLocks)\n private _firstNumber: number\n private _lastNumber: number\n\n protected constructor(params: HydratedBlockRangeStoreParams, firstNumber: number, lastNumber: number) {\n super(params)\n this._firstNumber = firstNumber\n this._lastNumber = lastNumber\n }\n\n get count(): number {\n return this._lastNumber - this._firstNumber + 1\n }\n\n get numberRange(): [number, number] {\n return [this._firstNumber, this._lastNumber]\n }\n\n get range(): [Hash, Hash] {\n return [this.params.first, this.params.last]\n }\n\n static async create(params: HydratedBlockRangeStoreParams): Promise<IndexedHydratedBlockRangeStore> {\n const firstBlock = asBlockBoundWitness((await params.sourceArchivist.get([params.first])).at(0)\n ?? (await params.snapshotArchivist.get([params.first])).at(0))\n const firstBlockExisting = assertEx(firstBlock, () => 'First block not found')\n\n const lastBlock = asBlockBoundWitness((await params.sourceArchivist.get([params.last])).at(0)\n ?? (await params.snapshotArchivist.get([params.last])).at(0))\n const lastBlockExisting = assertEx(lastBlock, () => 'Last block not found')\n\n // getting the block numbers here since can not get them in the constructor\n const result = new IndexedHydratedBlockRangeStore(params, firstBlockExisting.block, lastBlockExisting.block)\n result.createSubscriptions()\n await result.index()\n return result\n }\n\n async first(): Promise<HydratedBlock> {\n return assertEx(await this.fromHash(this.params.first), () => 'First block not found')\n }\n\n async fromHash(hash: Hash): Promise<HydratedBlock | undefined> {\n const chainMap = readPayloadMapFromStore<WithStorageMeta<Payload>>(this.params.sourceArchivist)\n const snapshotMap = readPayloadMapFromStore<WithStorageMeta<Payload>>(this.params.snapshotArchivist)\n const block = (await hydrateBlock({ chainMap }, hash))\n ?? (await hydrateBlock({ chainMap: snapshotMap }, hash))\n if (isDefined(block) && (block[0].block <= this._lastNumber && block[0].block >= this._firstNumber)) {\n return block\n }\n }\n\n fromNumber(number: number): Promisable<HydratedBlock | undefined> {\n const hash = this._blockNumberIndex.get(number)\n if (isDefined(hash)) {\n return this.fromHash(hash)\n }\n }\n\n async last(): Promise<HydratedBlock> {\n return assertEx(await this.fromHash(this.params.last), () => 'Last block not found')\n }\n\n async next(from: HydratedBlock): Promise<HydratedBlock | undefined>\n async next(from: HydratedBlock, count: number): Promise<HydratedBlock[]>\n async next(from: HydratedBlock, count?: number): Promise<HydratedBlock | HydratedBlock[] | undefined> {\n const nextBlockNumber = from[0].block + 1\n if (nextBlockNumber > this._lastNumber) {\n return isDefined(count) ? [] : undefined\n }\n if (isDefined(count)) {\n if (count === 0) {\n return []\n }\n const nextBlock = await this.fromNumber(nextBlockNumber)\n\n if (isDefined(nextBlock)) {\n return [nextBlock, ...await this.next(nextBlock, count - 1)].filter(exists)\n } else {\n if (from[0].block < this._lastNumber) {\n throw new Error(`Next block [${nextBlockNumber}] not found, but should be in range`)\n }\n return []\n }\n } else {\n return await this.fromNumber(nextBlockNumber)\n }\n }\n\n async prev(from: HydratedBlock): Promise<HydratedBlock | undefined>\n async prev(from: HydratedBlock, count: number): Promise<HydratedBlock[]>\n async prev(from: HydratedBlock, count?: number): Promise<HydratedBlock | HydratedBlock[] | undefined> {\n const prevBlockNumber = from[0].block - 1\n if (prevBlockNumber < this._firstNumber) {\n return isDefined(count) ? [] : undefined\n }\n if (isDefined(count)) {\n if (count === 0) {\n return []\n }\n const prevBlock = await this.fromNumber(prevBlockNumber)\n if (isDefined(prevBlock)) {\n return [...await this.next(prevBlock, count - 1), prevBlock].filter(exists)\n } else {\n if (from[0].block > this._firstNumber) {\n throw new Error(`Prev block [${prevBlockNumber}] not found, but should be in range`)\n }\n return []\n }\n } else {\n return await this.fromNumber(prevBlockNumber)\n }\n }\n\n private createSubscriptions(): void {\n // we monitor deletes so that we can keep them if we need them for the window\n this.params.sourceArchivist.on('deleted', async ({ payloads }) => {\n await this.params.snapshotArchivist.insert(payloads)\n })\n }\n\n private async index() {\n // get all the locks (make exclusive)\n await this._blockNumberIndexSemaphore.acquire(BlockNumberIndexSemaphoreLocks)\n try {\n this._blockNumberIndex.clear()\n let blockToIndex: Hash = this.params.last\n let firstFound = false\n while (!firstFound) {\n const payload = assertEx((await this.params.sourceArchivist.get([blockToIndex])).at(0), () => 'Block payload not found')\n const block = assertEx(asBlockBoundWitnessWithStorageMeta(payload), () => 'Payload is not a Block')\n if (block.block < this._firstNumber || block.block > this._lastNumber) {\n throw new Error(`Block [${block.block}] is out of range`)\n }\n this._blockNumberIndex.set(block.block, block._hash)\n firstFound = block.block === this._firstNumber\n }\n } finally {\n this._blockNumberIndexSemaphore.release(BlockNumberIndexSemaphoreLocks)\n }\n }\n}\n","export * from './block/index.ts'\nexport * from '@xyo-network/xl1-sdk'\n"],"mappings":"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","names":["hexToBigInt","validateHydratedBlock","validateHydratedBlockState","PayloadBuilder","createSignatureWrappers","HydratedTransactionWrapper","isSignedTransactionBoundWitnessWithStorageMeta","isTransfer","XYO_ZERO_ADDRESS","sumTransfers","payload","total","i","Object","values","transfers","hexToBigInt","HydratedBlockWrapper","data","allPayloadsCache","context","transactionsCache","_parseErrors","_signatureCache","block","boundWitness","chain","parseErrors","payloadCount","length","payloads","reward","reduce","acc","isTransfer","from","XYO_ZERO_ADDRESS","signatureCount","signatures","stepHashes","step_hashes","transactionCount","transactions","parse","validate","wrapper","index","at","signature","transaction","validateHydratedBlock","validateState","services","validateHydratedBlockState","allPayloads","PayloadBuilder","addStorageMeta","isSignedTransactionBoundWitnessWithStorageMeta","hydratedTransaction","filter","p","payload_hashes","includes","_hash","_dataHash","push","HydratedTransactionWrapper","createSignatureWrappers","assertEx","BaseEmitter","exists","isDefined","asBlockBoundWitness","asBlockBoundWitnessWithStorageMeta","hydrateBlock","readPayloadMapFromStore","Semaphore","BlockNumberIndexSemaphoreLocks","IndexedHydratedBlockRangeStore","BaseEmitter","_blockNumberIndex","Map","_blockNumberIndexSemaphore","Semaphore","_firstNumber","_lastNumber","params","firstNumber","lastNumber","count","numberRange","range","first","last","create","firstBlock","asBlockBoundWitness","sourceArchivist","get","at","snapshotArchivist","firstBlockExisting","assertEx","lastBlock","lastBlockExisting","result","block","createSubscriptions","index","fromHash","hash","chainMap","readPayloadMapFromStore","snapshotMap","hydrateBlock","isDefined","fromNumber","number","next","from","nextBlockNumber","undefined","nextBlock","filter","exists","Error","prev","prevBlockNumber","prevBlock","on","payloads","insert","acquire","clear","blockToIndex","firstFound","payload","asBlockBoundWitnessWithStorageMeta","set","_hash","release"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "$schema": "http://json.schemastore.org/package.json",
3
3
  "name": "@xyo-network/chain-wrappers",
4
- "version": "1.18.5",
4
+ "version": "1.19.0",
5
5
  "description": "XYO Layer One SDK Wrappers",
6
6
  "homepage": "https://xylabs.com",
7
7
  "bugs": {
@@ -40,15 +40,15 @@
40
40
  ],
41
41
  "dependencies": {
42
42
  "@xylabs/sdk-js": "~5.0.64",
43
- "@xyo-network/archivist-model": "~5.2.25",
44
- "@xyo-network/chain-validation": "~1.18.5",
45
- "@xyo-network/payload-builder": "~5.2.25",
46
- "@xyo-network/payload-model": "~5.2.25",
47
- "@xyo-network/xl1-sdk": "~1.19.6",
43
+ "@xyo-network/archivist-model": "~5.3.2",
44
+ "@xyo-network/chain-validation": "~1.19.0",
45
+ "@xyo-network/payload-builder": "~5.3.2",
46
+ "@xyo-network/payload-model": "~5.3.2",
47
+ "@xyo-network/xl1-sdk": "~1.20.2",
48
48
  "async-mutex": "~0.5.0"
49
49
  },
50
50
  "devDependencies": {
51
- "@types/node": "~25.0.10",
51
+ "@types/node": "~25.1.0",
52
52
  "@xylabs/ts-scripts-yarn3": "~7.3.2",
53
53
  "@xylabs/tsconfig": "~7.3.2",
54
54
  "eslint": "^9.39.2",
@@ -5,6 +5,7 @@ import { PayloadBuilder } from '@xyo-network/payload-builder'
5
5
  import type { WithHashMeta } from '@xyo-network/payload-model'
6
6
  import type {
7
7
  AccountBalanceViewer,
8
+ BaseContext,
8
9
  HydratedBlockInstance, HydratedBlockWithHashMeta, HydratedTransactionInstance, SignatureInstance,
9
10
  SignedHydratedTransactionWithStorageMeta, Transfer,
10
11
  } from '@xyo-network/xl1-sdk'
@@ -25,12 +26,14 @@ const sumTransfers = (payload: Transfer) => {
25
26
  export class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implements HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]> {
26
27
  data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]
27
28
  protected allPayloadsCache: WithHashMeta<T[1][number]>[] = []
29
+ protected context: BaseContext
28
30
  protected transactionsCache: HydratedTransactionInstance[] = []
29
31
  private _parseErrors: Error[] = []
30
32
  private _signatureCache: SignatureInstance[] = []
31
33
 
32
- protected constructor(data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]) {
34
+ protected constructor(context: BaseContext, data: [WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]) {
33
35
  this.data = data
36
+ this.context = context
34
37
  }
35
38
 
36
39
  get block() {
@@ -86,8 +89,8 @@ export class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implement
86
89
  return this.transactionsCache
87
90
  }
88
91
 
89
- static async parse<T extends HydratedBlockWithHashMeta>(block: T, validate = false): Promise<HydratedBlockInstance> {
90
- const wrapper = new HydratedBlockWrapper(block)
92
+ static async parse<T extends HydratedBlockWithHashMeta>(context: BaseContext, block: T, validate = false): Promise<HydratedBlockInstance> {
93
+ const wrapper = new HydratedBlockWrapper(context, block)
91
94
  return await wrapper.parse(validate)
92
95
  }
93
96
 
@@ -104,11 +107,11 @@ export class HydratedBlockWrapper<T extends HydratedBlockWithHashMeta> implement
104
107
  }
105
108
 
106
109
  async validate(): Promise<Error[]> {
107
- return await validateHydratedBlock(this.data)
110
+ return await validateHydratedBlock(this.context, this.data)
108
111
  }
109
112
 
110
113
  async validateState(services: { accountBalance: AccountBalanceViewer }): Promise<Error[]> {
111
- return await validateHydratedBlockState(this.data, () => this.chain, services)
114
+ return await validateHydratedBlockState(this.context, this.data, () => this.chain, services)
112
115
  }
113
116
 
114
117
  protected async parse(validate = false): Promise<HydratedBlockInstance<[WithHashMeta<T[0]>, WithHashMeta<T[1][number]>[]]>> {