@xyo-network/xl1-protocol-sdk 1.15.3 → 1.15.5
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/dist/neutral/block/primitives/balances/balancesStepSummaryFromRange.d.ts.map +1 -1
- package/dist/neutral/block/primitives/model.d.ts +2 -0
- package/dist/neutral/block/primitives/model.d.ts.map +1 -1
- package/dist/neutral/block/primitives/transfers/transfersStepSummaryFromRange.d.ts.map +1 -1
- package/dist/neutral/index.mjs +50 -40
- package/dist/neutral/index.mjs.map +1 -1
- package/package.json +3 -2
- package/src/block/primitives/balances/balancesStepSummaryFromRange.ts +26 -20
- package/src/block/primitives/model.ts +2 -0
- package/src/block/primitives/transfers/transfersStepSummaryFromRange.ts +29 -24
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"balancesStepSummaryFromRange.d.ts","sourceRoot":"","sources":["../../../../../src/block/primitives/balances/balancesStepSummaryFromRange.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"balancesStepSummaryFromRange.d.ts","sourceRoot":"","sources":["../../../../../src/block/primitives/balances/balancesStepSummaryFromRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AASjE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAG1D,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,EAAE,KAAK,mBAAmB,EAA6B,MAAM,sBAAsB,CAAA;AAE1F,wBAAsB,4BAA4B,CAChD,OAAO,EAAE,yBAAyB,EAClC,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC,CA+D/C"}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import type { ReadArchivist } from '@xyo-network/archivist-model';
|
|
2
2
|
import type { Payload } from '@xyo-network/payload-model';
|
|
3
|
+
import type { Semaphore } from 'async-mutex';
|
|
3
4
|
import type { MapTypeRead, MapTypeWrite } from '../../map/index.ts';
|
|
4
5
|
import type { ChainContextRead } from '../../model/index.ts';
|
|
5
6
|
import type { BalancesStepSummary, TransfersStepSummary } from './payloads/index.ts';
|
|
6
7
|
export declare function isReadArchivist(obj: unknown): obj is ReadArchivist;
|
|
7
8
|
export interface ChainSummaryContextRead<T extends Payload> extends ChainContextRead {
|
|
9
|
+
stepSemaphores: Semaphore[];
|
|
8
10
|
summaryMap: MapTypeRead<string, T>;
|
|
9
11
|
windowSize?: number;
|
|
10
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../../../src/block/primitives/model.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;AACjE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../../../../src/block/primitives/model.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;AACjE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAE5C,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AACnE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AAC5D,OAAO,KAAK,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAEpF,wBAAgB,eAAe,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,aAAa,CAElE;AAED,MAAM,WAAW,uBAAuB,CAAC,CAAC,SAAS,OAAO,CAAE,SAAQ,gBAAgB;IAClF,cAAc,EAAE,SAAS,EAAE,CAAA;IAC3B,UAAU,EAAE,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAA;IAClC,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,MAAM,WAAW,wBAAwB,CAAC,CAAC,SAAS,OAAO,CAAE,SAAQ,gBAAgB;IACnF,UAAU,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC,CAAA;CACpC;AAED,MAAM,MAAM,mBAAmB,CAAC,CAAC,SAAS,OAAO,IAAI,uBAAuB,CAAC,CAAC,CAAC,GAAG,wBAAwB,CAAC,CAAC,CAAC,CAAA;AAE7G,MAAM,WAAW,yBAA0B,SAAQ,mBAAmB,CAAC,mBAAmB,CAAC;CAAG;AAE9F,MAAM,WAAW,2BAA4B,SAAQ,mBAAmB,CAAC,oBAAoB,CAAC;CAAG"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transfersStepSummaryFromRange.d.ts","sourceRoot":"","sources":["../../../../../src/block/primitives/transfers/transfersStepSummaryFromRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AASjE,OAAO,EAAE,KAAK,gBAAgB,EAAgC,MAAM,oBAAoB,CAAA;AAExF,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAA;AAC9D,OAAO,EAAE,KAAK,oBAAoB,EAA8B,MAAM,sBAAsB,CAAA;AAE5F,wBAAsB,6BAA6B,CACjD,OAAO,EAAE,2BAA2B,EACpC,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"transfersStepSummaryFromRange.d.ts","sourceRoot":"","sources":["../../../../../src/block/primitives/transfers/transfersStepSummaryFromRange.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AASjE,OAAO,EAAE,KAAK,gBAAgB,EAAgC,MAAM,oBAAoB,CAAA;AAExF,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAA;AAC9D,OAAO,EAAE,KAAK,oBAAoB,EAA8B,MAAM,sBAAsB,CAAA;AAE5F,wBAAsB,6BAA6B,CACjD,OAAO,EAAE,2BAA2B,EACpC,KAAK,EAAE,gBAAgB,GACtB,OAAO,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC,CAwEhD"}
|
package/dist/neutral/index.mjs
CHANGED
|
@@ -279,26 +279,31 @@ async function balancesStepSummaryFromRange(context, range) {
|
|
|
279
279
|
if (isAnyPayload(summaryResult)) {
|
|
280
280
|
result = summaryResult;
|
|
281
281
|
} else {
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
282
|
+
await context.stepSemaphores[step].acquire();
|
|
283
|
+
try {
|
|
284
|
+
const subRanges = deepCalculateFramesFromRange(range, step - 1);
|
|
285
|
+
const promises = subRanges.map((subRange) => balancesStepSummaryFromRange(context, subRange));
|
|
286
|
+
const subResults = await Promise.all(promises);
|
|
287
|
+
const bigIntBalances = {};
|
|
288
|
+
for (const subResult of subResults) {
|
|
289
|
+
for (const [address, balance] of Object.entries(subResult.balances)) {
|
|
290
|
+
bigIntBalances[address] = (bigIntBalances[address] ?? 0n) + parseSignedBigInt(balance);
|
|
291
|
+
}
|
|
289
292
|
}
|
|
293
|
+
const balances = {};
|
|
294
|
+
for (const [address, balance] of Object.entries(bigIntBalances)) {
|
|
295
|
+
balances[address] = toSignedBigInt(balance);
|
|
296
|
+
}
|
|
297
|
+
result = {
|
|
298
|
+
schema: BalancesStepSummarySchema,
|
|
299
|
+
hash: frameHeadHash,
|
|
300
|
+
stepSize: frameSize,
|
|
301
|
+
balances
|
|
302
|
+
};
|
|
303
|
+
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result);
|
|
304
|
+
} finally {
|
|
305
|
+
context.stepSemaphores[step].release();
|
|
290
306
|
}
|
|
291
|
-
const balances = {};
|
|
292
|
-
for (const [address, balance] of Object.entries(bigIntBalances)) {
|
|
293
|
-
balances[address] = toSignedBigInt(balance);
|
|
294
|
-
}
|
|
295
|
-
result = {
|
|
296
|
-
schema: BalancesStepSummarySchema,
|
|
297
|
-
hash: frameHeadHash,
|
|
298
|
-
stepSize: frameSize,
|
|
299
|
-
balances
|
|
300
|
-
};
|
|
301
|
-
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result);
|
|
302
307
|
}
|
|
303
308
|
}
|
|
304
309
|
const finalResult = await PayloadBuilder.addStorageMeta(result);
|
|
@@ -375,32 +380,37 @@ async function transfersStepSummaryFromRange(context, range) {
|
|
|
375
380
|
if (isAnyPayload2(summaryResult)) {
|
|
376
381
|
result = summaryResult;
|
|
377
382
|
} else {
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
for (const [
|
|
386
|
-
bigIntBalances[from]
|
|
383
|
+
await context.stepSemaphores[step].acquire();
|
|
384
|
+
try {
|
|
385
|
+
const subRanges = deepCalculateFramesFromRange(range, step - 1);
|
|
386
|
+
const promises = subRanges.map((subRange) => transfersStepSummaryFromRange(context, subRange));
|
|
387
|
+
const subResults = await Promise.all(promises);
|
|
388
|
+
const bigIntBalances = {};
|
|
389
|
+
for (const subResult of subResults) {
|
|
390
|
+
for (const [from, toMap] of Object.entries(subResult.transfers)) {
|
|
391
|
+
bigIntBalances[from] = bigIntBalances[from] ?? {};
|
|
392
|
+
for (const [to, transfer] of Object.entries(toMap)) {
|
|
393
|
+
bigIntBalances[from][to] = (bigIntBalances[from][to] ?? 0n) + parseSignedBigInt(transfer);
|
|
394
|
+
}
|
|
387
395
|
}
|
|
388
396
|
}
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
397
|
+
const transfers = {};
|
|
398
|
+
for (const [from, toMap] of Object.entries(bigIntBalances)) {
|
|
399
|
+
transfers[from] = transfers[from] ?? {};
|
|
400
|
+
for (const [to, transfer] of Object.entries(toMap)) {
|
|
401
|
+
transfers[from][to] = toSignedBigInt(transfer);
|
|
402
|
+
}
|
|
395
403
|
}
|
|
404
|
+
result = {
|
|
405
|
+
schema: TransfersStepSummarySchema,
|
|
406
|
+
hash: frameHeadHash,
|
|
407
|
+
stepSize: frameSize,
|
|
408
|
+
transfers
|
|
409
|
+
};
|
|
410
|
+
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result);
|
|
411
|
+
} finally {
|
|
412
|
+
context.stepSemaphores[step].release();
|
|
396
413
|
}
|
|
397
|
-
result = {
|
|
398
|
-
schema: TransfersStepSummarySchema,
|
|
399
|
-
hash: frameHeadHash,
|
|
400
|
-
stepSize: frameSize,
|
|
401
|
-
transfers
|
|
402
|
-
};
|
|
403
|
-
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result);
|
|
404
414
|
}
|
|
405
415
|
}
|
|
406
416
|
const finalResult = await PayloadBuilder2.addStorageMeta(result);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/block/hydrate/allHashesPresent.ts","../../src/block/hydrate/blockPayloadsFromHydratedBlock.ts","../../src/block/hydrate/flattenHydratedBlock.ts","../../src/block/hydrate/flattenHydratedBlocks.ts","../../src/block/hydrate/hydrateBlock.ts","../../src/block/primitives/balances/balancesStepSummaryFromRange.ts","../../src/payload/netBalancesForPayloads.ts","../../src/payload/netTransfersForPayloads.ts","../../src/SignedBigInt.ts","../../src/block/primitives/frames/calculateFramesFromRange.ts","../../src/block/primitives/frames/deepCalculateFramesFromRange.ts","../../src/block/primitives/blockFromBlockNumber.ts","../../src/block/primitives/hashFromBlockNumber.ts","../../src/block/primitives/payloads/BalancesStepSummary.ts","../../src/block/primitives/payloads/StepSummary.ts","../../src/block/primitives/payloads/TransfersSummary.ts","../../src/block/primitives/balances/balancesSummary.ts","../../src/block/primitives/model.ts","../../src/block/primitives/transfers/transfersStepSummaryFromRange.ts","../../src/block/primitives/transfers/transfersSummary.ts","../../src/block/hydrate/transactionsFromHydratedBlock.ts","../../src/block/hydrate/tryHydrateBlock.ts","../../src/config/Config.ts","../../src/config/Api.ts","../../src/validation/lib/isLocalhost.ts","../../src/validation/lib/getUrl.ts","../../src/validation/schema/Address.ts","../../src/validation/schema/Mnemonic.ts","../../src/config/App.ts","../../src/config/Bridge.ts","../../src/config/Chain.ts","../../src/config/Evm.ts","../../src/config/Log.ts","../../src/config/Producer.ts","../../src/config/storage/driver/Mongo.ts","../../src/config/storage/Storage.ts","../../src/config/Telemetry.ts","../../src/config/UsageMeta.ts","../../src/model/StakeEvents.ts","../../src/steps/primitives/addressStakeWeight.ts","../../src/steps/primitives/claimedRewards.ts","../../src/steps/primitives/stakersAsOfBlock.ts","../../src/steps/primitives/startingStakes.ts","../../src/steps/primitives/totalStakeWeight.ts","../../src/steps/primitives/unclaimedRewards.ts","../../src/time/primitives/xl1BlockNumberToEthBlockNumber.ts","../../src/transaction/buildTransaction.ts","../../src/transaction/buildUnsignedTransaction.ts","../../src/transaction/confirmSubmittedTransaction.ts","../../src/transaction/hydrateTransaction.ts","../../src/transaction/primitives/transactionBlockByteCount.ts","../../src/transaction/primitives/transactionElevatedPayloads.ts","../../src/transaction/primitives/transactionOperations.ts","../../src/transaction/primitives/transactionRequiredGas.ts","../../src/transaction/script.ts","../../src/transaction/signTransaction.ts","../../src/wallet/generateXyoBaseWalletFromPhrase.ts","../../src/wallet/paths.ts"],"sourcesContent":["import type { Hash } from '@xylabs/hex'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\n\nexport function allHashesPresent(hashes: Hash[], payloads: WithStorageMeta<Payload>[]): boolean {\n const payloadHashes = new Set(payloads.map(p => p._hash))\n return hashes.every(hash => payloadHashes.has(hash))\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const blockPayloadsFromHydratedBlock = (block: HydratedBlock): WithStorageMeta<Payload>[] => {\n return block[0].payload_hashes.map(hash => assertEx(\n block[1].find(p => p._hash === hash),\n () => `missing payload ${hash}`,\n )).filter(x => !isTransactionBoundWitnessWithStorageMeta(x))\n}\n","import type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\n\nexport const flattenHydratedBlock = (hydratedBlock: HydratedBlock): WithStorageMeta<Payload>[] => {\n const [blk, blkPayloads] = hydratedBlock\n return [...blkPayloads, blk]\n}\n","import type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\n\nimport { flattenHydratedBlock } from './flattenHydratedBlock.ts'\n\nexport const flattenHydratedBlocks = (hydratedBlocks: HydratedBlock[]): WithStorageMeta<Payload>[] =>\n hydratedBlocks.flatMap(blk => flattenHydratedBlock(blk))\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport { isDefined } from '@xylabs/typeof'\nimport { type ReadArchivist } from '@xyo-network/archivist-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { asBlockBoundWitnessWithStorageMeta, isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport type { ChainStoreRead, PayloadMapRead } from '../../model/index.ts'\nimport { isReadArchivist } from '../primitives/index.ts'\nimport { allHashesPresent } from './allHashesPresent.ts'\n\nexport function readPayloadMapFromStore<T extends Payload>(store: ReadArchivist<T> | PayloadMapRead<T>): PayloadMapRead<T> {\n if (isReadArchivist(store)) {\n return {\n get: async (hash: Hash): Promise<T | undefined> => {\n return (await store.get([hash]))[0]\n },\n getMany: async (hashes: Hash[]): Promise<T[]> => {\n return (await store.get(hashes))\n },\n has: async (hash: Hash): Promise<boolean> => {\n return isDefined((await store.get([hash]))[0])\n },\n }\n }\n return store\n}\n\nexport const hydrateBlock = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n maxDepth: number = 1,\n minDepth = maxDepth,\n): Promise<HydratedBlock> => {\n assertEx(maxDepth >= 0, () => 'maxDepth must be greater than or equal to 0')\n assertEx(minDepth >= 0, () => 'minDepth must be greater than or equal to 0')\n assertEx(maxDepth >= minDepth, () => 'maxDepth must be greater than or equal to minDepth')\n\n const bw = assertEx(asBlockBoundWitnessWithStorageMeta(\n assertEx(await chainMap.get(hash), () => `block ${hash} not found`),\n ), () => `hash ${hash} is not a BlockBoundWitness`)\n\n if (maxDepth === 0) return [bw, []]\n const blkPayloads = await chainMap.getMany(bw.payload_hashes)\n if (minDepth === 1) assertEx(allHashesPresent(bw.payload_hashes, blkPayloads), () => `Unable to find all payloads for block ${hash}`)\n if (maxDepth === 1) return [bw, blkPayloads]\n const transactions = blkPayloads.filter(isTransactionBoundWitnessWithStorageMeta)\n const transactionsPayloadHashes = transactions.flatMap(tx => tx.payload_hashes)\n const transactionsPayloads = await chainMap.getMany(transactionsPayloadHashes)\n assertEx(allHashesPresent(transactionsPayloadHashes, transactionsPayloads), () => `Unable to find all payloads for transactions in block ${hash}`)\n const allPayloadsHashes = new Set([...blkPayloads, ...transactionsPayloads].flatMap(p => p._hash))\n const allPayloads = await chainMap.getMany([...allPayloadsHashes])\n const allPayloadsFiltered = allPayloads.filter(p => allPayloadsHashes.has(p._hash))\n if (maxDepth === 2) assertEx(allHashesPresent(\n [...allPayloadsHashes],\n allPayloadsFiltered,\n ), () => `Unable to find all payloads for transactions in block ${hash}`)\n return [bw, allPayloadsFiltered]\n}\n","import { assertEx } from '@xylabs/assert'\nimport { type Address } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport { netBalancesForPayloads } from '../../../payload/index.ts'\nimport {\n parseSignedBigInt, type SignedBigInt, toSignedBigInt,\n} from '../../../SignedBigInt.ts'\nimport { hydrateBlock } from '../../hydrate/index.ts'\nimport type { BlockNumberRange } from '../frames/index.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport { hashFromBlockNumber } from '../hashFromBlockNumber.ts'\nimport type { BalanceStepSummaryContext } from '../model.ts'\nimport { type BalancesStepSummary, BalancesStepSummarySchema } from '../payloads/index.ts'\n\nexport async function balancesStepSummaryFromRange(\n context: BalanceStepSummaryContext,\n range: BlockNumberRange,\n): Promise<WithStorageMeta<BalancesStepSummary>> {\n // console.log(`balanceStepSummaryFromRange: head=${head}, range=${range[0]}-${range[1]}`)\n const frameHeadHash = await hashFromBlockNumber(context, range[1])\n const frameSize = range[1] - range[0] + 1\n const head = await context.head()\n\n let result: BalancesStepSummary | undefined = undefined\n\n if (frameSize === 1) {\n const hash = await hashFromBlockNumber(context, range[0])\n const [, payloads] = await hydrateBlock(context.store, hash)\n const balances: Record<Address, SignedBigInt> = {}\n for (const [address, balance] of Object.entries(netBalancesForPayloads(payloads))) {\n balances[address as Address] = toSignedBigInt(balance)\n }\n result = {\n schema: BalancesStepSummarySchema, hash: head, stepSize: -1, balances,\n }\n } else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const step = (StepSizes as any).indexOf(frameSize)\n assertEx(step !== -1, () => `Invalid step size: ${frameSize}. Must be one of ${StepSizes.join(', ')}`)\n\n const summaryResult = await context.summaryMap.get(`${frameHeadHash}|${frameSize}`)\n if (isAnyPayload(summaryResult)) {\n result = summaryResult as WithStorageMeta<BalancesStepSummary>\n } else {\n // We do not have it, so lets build it\n const subRanges = deepCalculateFramesFromRange(range, step - 1)\n const promises = subRanges.map(subRange => balancesStepSummaryFromRange(\n context,\n subRange,\n ))\n const subResults = await Promise.all(promises)\n\n // add them all up\n const bigIntBalances: Record<Address, bigint> = {}\n for (const subResult of subResults) {\n for (const [address, balance] of Object.entries(subResult.balances)) {\n bigIntBalances[address as Address] = (bigIntBalances[address as Address] ?? 0n) + parseSignedBigInt(balance)\n }\n }\n\n const balances: Record<Address, SignedBigInt> = {}\n for (const [address, balance] of Object.entries(bigIntBalances)) {\n balances[address as Address] = toSignedBigInt(balance)\n }\n\n result = {\n schema: BalancesStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, balances,\n }\n\n await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)\n }\n }\n // console.log(`balanceStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)\n const finalResult = await PayloadBuilder.addStorageMeta(result)\n return finalResult\n}\n","import {\n type Address, type Hex, hexToBigInt, toAddress,\n} from '@xylabs/hex'\nimport { span } from '@xylabs/telemetry'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isTransfer } from '@xyo-network/xl1-protocol'\n\nexport const netBalancesForPayloads = (payloads: Payload[]) => {\n return span('netBalancesForPayloads', () => {\n const balances: Record<Address, bigint> = {}\n for (const payload of payloads) {\n if (isTransfer(payload)) {\n const { from } = payload\n for (let [address, amount] of Object.entries(payload.transfers) as [Address, Hex][]) {\n balances[toAddress(address)] = (balances[toAddress(address)] ?? 0n) + hexToBigInt(amount)\n balances[toAddress(from)] = (balances[toAddress(from)] ?? 0n) - hexToBigInt(amount)\n }\n }\n }\n return balances\n })\n}\n","import {\n type Address, type Hex, hexToBigInt,\n} from '@xylabs/hex'\nimport { span } from '@xylabs/telemetry'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isTransfer } from '@xyo-network/xl1-protocol'\n\n// the net transfer amounts for the specified accounts only\nexport function netTransfersForPayloads(payloads: Payload[]): Record<Address, Record<Address, bigint>> {\n return span('netTransfersForPayloads', () => {\n const transfers: Record<Address, Record<Address, bigint>> = {}\n for (const payload of payloads) {\n if (isTransfer(payload)) {\n const { from } = payload\n transfers[from] = transfers[from] ?? {}\n for (let [to, amount] of Object.entries(payload.transfers) as [Address, Hex][]) {\n transfers[to] = transfers[to] ?? {}\n transfers[to][from] = (transfers[to][from] ?? 0n) + hexToBigInt(amount)\n transfers[from][to] = (transfers[from][to] ?? 0n) - hexToBigInt(amount)\n }\n }\n }\n return transfers\n })\n}\n","import {\n type Hex,\n hexToBigInt,\n toHex,\n} from '@xylabs/hex'\nimport { isObject } from '@xylabs/object'\n\nexport interface NegativeBigInt {\n negative: Hex\n}\n\nexport interface PositiveBigInt {\n positive: Hex\n}\n\nexport type SignedBigInt = NegativeBigInt | PositiveBigInt\n\nexport const isNegativeBigInt = (value: unknown): value is NegativeBigInt => {\n return isObject(value) && 'negative' in value && typeof value.negative === 'string'\n}\n\nexport const isPositiveBigInt = (value: unknown): value is PositiveBigInt => {\n return isObject(value) && 'positive' in value && typeof value.positive === 'string'\n}\n\nexport const parseSignedBigInt = (value: SignedBigInt): bigint => {\n if (isNegativeBigInt(value)) {\n return -hexToBigInt(value.negative)\n } else if (isPositiveBigInt(value)) {\n return hexToBigInt(value.positive)\n } else {\n throw new Error('Invalid balance type')\n }\n}\n\nexport const toSignedBigInt = (value: bigint): SignedBigInt => {\n return value < 0n ? { negative: toHex(-value) } : { positive: toHex(value) }\n}\n\nexport const toPositiveBigInt = (value: unknown): PositiveBigInt => {\n if (isNegativeBigInt(value)) {\n return { positive: toHex(0n) }\n }\n if (isPositiveBigInt(value)) {\n return { positive: value.positive }\n }\n if (typeof value === 'bigint') {\n return { positive: toHex(value) }\n }\n throw new Error('Invalid value for positive big int')\n}\n","import { stepSize } from '@xyo-network/xl1-protocol'\n\nimport type { BlockNumberRange } from './BlockNumberRange.ts'\n\nexport function calculateFramesFromRange(range: BlockNumberRange, step: number): [\n // ranges of fitted frames\n BlockNumberRange[],\n // ranges of remaining blocks\n BlockNumberRange[]] {\n const size = stepSize(step)\n let start = (Math.trunc(range[0] / size)) * size\n const fitted: BlockNumberRange[] = []\n const remaining: BlockNumberRange[] = []\n\n // if the start is not aligned with the range, add a remaining block\n if (start !== range[0]) {\n start += size\n remaining.push([range[0], Math.min(start - 1, range[1])])\n }\n\n for (let i = start; i <= range[1]; i += size) {\n if ((i + size - 1) <= range[1]) {\n fitted.push([i, Math.min(i + size - 1, range[1])])\n } else {\n remaining.push([i, range[1]])\n }\n }\n return [fitted, remaining]\n}\n","import { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport type { BlockNumberRange } from './BlockNumberRange.ts'\nimport { calculateFramesFromRange } from './calculateFramesFromRange.ts'\n\nexport function deepCalculateFramesFromRange(range: BlockNumberRange, startingStep = StepSizes.length - 1): BlockNumberRange[] {\n const fitted: BlockNumberRange[] = []\n let remaining: BlockNumberRange[] = [range]\n\n for (let step = startingStep; step >= 0; step--) {\n const newRemaining: BlockNumberRange[] = []\n for (const range of remaining) {\n const [newFittedFrames, newRemainingFrames] = calculateFramesFromRange(range, step)\n fitted.push(...newFittedFrames)\n newRemaining.push(...newRemainingFrames)\n }\n remaining = newRemaining\n }\n\n for (const range of remaining) {\n for (let i = range[0]; i <= range[1]; i++) {\n fitted.push([i, i]) // Add individual frames for remaining ranges\n }\n }\n\n return fitted.toSorted((a, b) => a[0] - b[0]) // Sort by start of range\n}\n","import { asHash, type Hash } from '@xylabs/hex'\nimport { toSafeJsonString } from '@xylabs/object'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { BlockBoundWitness } from '@xyo-network/xl1-protocol'\nimport { asBlockBoundWitnessWithStorageMeta, StepSizes } from '@xyo-network/xl1-protocol'\n\nimport type { ChainContextRead } from '../../model/index.ts'\n\nexport async function blockFromBlockNumber(context: ChainContextRead, blockNumber: number): Promise<WithStorageMeta<BlockBoundWitness>> {\n const head = await context.head()\n const result = await context.store.chainMap.get(head)\n let currentBlock = asBlockBoundWitnessWithStorageMeta(result, () => `Head block not found for hash: ${head}`, { required: true })\n while (currentBlock.block > blockNumber) {\n let jumpHash: Hash | null = currentBlock.previous\n let jumpBlockNumber = currentBlock.block - 1\n for (const [step, stepSize] of StepSizes.entries()) {\n const possibleJumpBlockNumber = currentBlock.block - stepSize\n if (possibleJumpBlockNumber >= blockNumber && possibleJumpBlockNumber <= jumpBlockNumber) {\n jumpBlockNumber = possibleJumpBlockNumber\n jumpHash = asHash(currentBlock.step_hashes.at(step), () => `Step hash not found for step ${step} in block ${currentBlock.block}`)\n }\n }\n const newBlock = await context.store.chainMap.get(\n asHash(jumpHash, () => `Jump hash not found for block number [${blockNumber}]: ${jumpBlockNumber} ${toSafeJsonString(currentBlock, 10)}`),\n )\n currentBlock = asBlockBoundWitnessWithStorageMeta(newBlock, () => `Block not found for hash: ${jumpHash}`, { required: true })\n if (currentBlock.block === blockNumber) {\n break\n }\n if (currentBlock.block < blockNumber) {\n throw new Error(`Block number ${blockNumber} is not a valid step block number for block ${context.head}.`)\n }\n }\n return currentBlock\n}\n","import { type Hash } from '@xylabs/hex'\n\nimport type { ChainContextRead } from '../../model/index.ts'\nimport { blockFromBlockNumber } from './blockFromBlockNumber.ts'\n\nexport async function hashFromBlockNumber(context: ChainContextRead, blockNumber: number): Promise<Hash> {\n return (await blockFromBlockNumber(context, blockNumber))._hash\n}\n","import type { Address } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Schema, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType, isStorageMeta } from '@xyo-network/payload-model'\n\nimport type { SignedBigInt } from '../../../SignedBigInt.ts'\nimport type { StepSummary } from './StepSummary.ts'\n\nexport const BalancesStepSummarySchema: Schema = 'network.xyo.step.summary.balances'\nexport type BalancesStepSummarySchema = typeof BalancesStepSummarySchema\n\nexport type BalancesStepSummary = StepSummary<{\n balances: Record<Address, SignedBigInt>\n}, BalancesStepSummarySchema>\n\n/**\n * Identity function for determining if an object is an BalancesStepSummary\n */\nexport const isBalancesStepSummary = isPayloadOfSchemaType<BalancesStepSummary>(BalancesStepSummarySchema)\nexport const asBalancesStepSummary = AsObjectFactory.create<BalancesStepSummary>(isBalancesStepSummary)\n\n/**\n * Identity function for determining if an object is an BalancesStepSummary with Storage Meta\n */\nexport const isBalancesStepSummaryWithStorageMeta = (value: unknown): value is WithStorageMeta<BalancesStepSummary> => {\n return isBalancesStepSummary(value) && isStorageMeta(value)\n}\nexport const asBalancesStepSummaryWithStorageMeta = AsObjectFactory.create<WithStorageMeta<BalancesStepSummary>>(isBalancesStepSummaryWithStorageMeta)\n","import type { Hash } from '@xylabs/hex'\nimport type { EmptyObject } from '@xylabs/object'\nimport type { Payload, Schema } from '@xyo-network/payload-model'\n\nexport const StepSummarySchema: Schema = 'network.xyo.step.summary'\nexport type StepSummarySchema = typeof StepSummarySchema\n\nexport interface StepSummaryFields {\n hash: Hash // the stepHash - the hash of the last block in the step frame\n stepSize: number // the stepSize in blocks\n}\n\nexport type StepSummary<TAdditionalFields extends EmptyObject | void = void,\n TSchema extends Schema | void = void> = Payload<TAdditionalFields extends void ? StepSummaryFields : TAdditionalFields & StepSummaryFields,\n TSchema extends void ? StepSummarySchema : TSchema>\n","import type { Address } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Schema, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType, isStorageMeta } from '@xyo-network/payload-model'\n\nimport type { SignedBigInt } from '../../../SignedBigInt.ts'\nimport type { StepSummary } from './StepSummary.ts'\n\nexport const TransfersStepSummarySchema: Schema = 'network.xyo.step.summary.transfer'\nexport type TransfersStepSummarySchema = typeof TransfersStepSummarySchema\n\nexport type TransfersStepSummary = StepSummary<{\n transfers: Record<Address, Record<Address, SignedBigInt>>\n}, TransfersStepSummarySchema>\n\n/**\n * Identity function for determining if an object is an TransfersStepSummary\n */\nexport const isTransfersStepSummary = isPayloadOfSchemaType<TransfersStepSummary>(TransfersStepSummarySchema)\nexport const asTransfersStepSummary = AsObjectFactory.create<TransfersStepSummary>(isTransfersStepSummary)\n\n/**\n * Identity function for determining if an object is an TransfersStepSummary with Storage Meta\n */\nexport const isTransfersStepSummaryWithStorageMeta = (value: unknown): value is WithStorageMeta<TransfersStepSummary> => {\n return isTransfersStepSummary(value) && isStorageMeta(value)\n}\nexport const asTransfersStepSummaryWithStorageMeta\n = AsObjectFactory.create<WithStorageMeta<TransfersStepSummary>>(isTransfersStepSummaryWithStorageMeta)\n","import type { Address } from '@xylabs/hex'\nimport { asAddress } from '@xylabs/hex'\nimport { spanRootAsync } from '@xylabs/telemetry'\nimport { isDefined } from '@xylabs/typeof'\nimport { asBlockBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport { parseSignedBigInt } from '../../../SignedBigInt.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport type { BalanceStepSummaryContext } from '../model.ts'\nimport { balancesStepSummaryFromRange } from './balancesStepSummaryFromRange.ts'\n\nexport async function balancesSummary(\n context: BalanceStepSummaryContext,\n): Promise<Partial<Record<Address, bigint>>> {\n return await spanRootAsync('balanceSummary', async () => {\n const head = await context.head()\n const headResult = await context.store.chainMap.get(head)\n const headBoundWitness = asBlockBoundWitnessWithStorageMeta(headResult, () => `Head block not found for hash: ${context.head}`, { required: true })\n const rangeStart = isDefined(context.windowSize) ? Math.max(headBoundWitness.block - context.windowSize + 1, 0) : 0\n const ranges = deepCalculateFramesFromRange([rangeStart, headBoundWitness.block])\n const summaries = await Promise.all(ranges.map(range => balancesStepSummaryFromRange(context, range)))\n const balances: Partial<Record<Address, bigint>> = {}\n for (let summary of summaries) {\n for (const [address, balance] of Object.entries(summary.balances)) {\n const validAddress = asAddress(address, () => `Invalid address: ${address}`)\n balances[validAddress] = (balances[validAddress] ?? 0n) + parseSignedBigInt(balance)\n }\n }\n return balances\n })\n}\n","import type { ReadArchivist } from '@xyo-network/archivist-model'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { MapTypeRead, MapTypeWrite } from '../../map/index.ts'\nimport type { ChainContextRead } from '../../model/index.ts'\nimport type { BalancesStepSummary, TransfersStepSummary } from './payloads/index.ts'\n\nexport function isReadArchivist(obj: unknown): obj is ReadArchivist {\n return (obj as ReadArchivist).get !== undefined && (obj as ReadArchivist).next !== undefined\n}\n\nexport interface ChainSummaryContextRead<T extends Payload> extends ChainContextRead {\n summaryMap: MapTypeRead<string, T>\n windowSize?: number\n}\n\nexport interface ChainSummaryContextWrite<T extends Payload> extends ChainContextRead {\n summaryMap: MapTypeWrite<string, T>\n}\n\nexport type ChainSummaryContext<T extends Payload> = ChainSummaryContextRead<T> & ChainSummaryContextWrite<T>\n\nexport interface BalanceStepSummaryContext extends ChainSummaryContext<BalancesStepSummary> {}\n\nexport interface TransfersStepSummaryContext extends ChainSummaryContext<TransfersStepSummary> {}\n","/* eslint-disable max-statements */\nimport { assertEx } from '@xylabs/assert'\nimport { type Address } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport { netTransfersForPayloads } from '../../../payload/index.ts'\nimport {\n parseSignedBigInt, type SignedBigInt, toSignedBigInt,\n} from '../../../SignedBigInt.ts'\nimport { hydrateBlock } from '../../hydrate/index.ts'\nimport { type BlockNumberRange, deepCalculateFramesFromRange } from '../frames/index.ts'\nimport { hashFromBlockNumber } from '../hashFromBlockNumber.ts'\nimport type { TransfersStepSummaryContext } from '../model.ts'\nimport { type TransfersStepSummary, TransfersStepSummarySchema } from '../payloads/index.ts'\n\nexport async function transfersStepSummaryFromRange(\n context: TransfersStepSummaryContext,\n range: BlockNumberRange,\n): Promise<WithStorageMeta<TransfersStepSummary>> {\n // console.log(`transfersStepSummaryFromRange: head=${head}, range=${range[0]}-${range[1]}`)\n const frameHeadHash = await hashFromBlockNumber(context, range[1])\n const frameSize = range[1] - range[0] + 1\n const head = await context.head()\n\n let result: TransfersStepSummary | undefined = undefined\n\n if (frameSize === 1) {\n const hash = await hashFromBlockNumber(context, range[0])\n const [, payloads] = await hydrateBlock(context.store, hash)\n const transfers: Record<Address, Record<Address, SignedBigInt>> = {}\n for (const [from, toMap] of Object.entries(netTransfersForPayloads(payloads))) {\n transfers[from as Address] = transfers[from as Address] ?? {}\n for (const [to, amount] of Object.entries(toMap)) {\n transfers[from as Address][to as Address] = toSignedBigInt(amount)\n }\n }\n result = {\n schema: TransfersStepSummarySchema, hash: head, stepSize: -1, transfers,\n }\n } else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const step = (StepSizes as any).indexOf(frameSize)\n assertEx(step !== -1, () => `Invalid step size: ${frameSize}. Must be one of ${StepSizes.join(', ')}`)\n\n const summaryResult = await context.summaryMap.get(`${frameHeadHash}|${frameSize}`)\n if (isAnyPayload(summaryResult)) {\n result = summaryResult as WithStorageMeta<TransfersStepSummary>\n } else {\n // We do not have it, so lets build it\n const subRanges = deepCalculateFramesFromRange(range, step - 1)\n const promises = subRanges.map(subRange => transfersStepSummaryFromRange(\n context,\n subRange,\n ))\n const subResults = await Promise.all(promises)\n\n // add them all up\n const bigIntBalances: Record<Address, Record<Address, bigint>> = {}\n for (const subResult of subResults) {\n for (const [from, toMap] of Object.entries(subResult.transfers)) {\n bigIntBalances[from as Address] = bigIntBalances[from as Address] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n bigIntBalances[from as Address][to as Address] = (bigIntBalances[from as Address][to as Address] ?? 0n) + parseSignedBigInt(transfer)\n }\n }\n }\n\n const transfers: Record<Address, Record<Address, SignedBigInt>> = {}\n for (const [from, toMap] of Object.entries(bigIntBalances)) {\n transfers[from as Address] = transfers[from as Address] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n transfers[from as Address][to as Address] = toSignedBigInt(transfer)\n }\n }\n\n result = {\n schema: TransfersStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, transfers,\n }\n\n await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)\n }\n }\n // console.log(`transfersStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)\n const finalResult = await PayloadBuilder.addStorageMeta(result)\n return finalResult\n}\n","import type { Address } from '@xylabs/hex'\nimport { asAddress } from '@xylabs/hex'\nimport { spanRootAsync } from '@xylabs/telemetry'\nimport { isDefined } from '@xylabs/typeof'\nimport { asBlockBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport { parseSignedBigInt } from '../../../SignedBigInt.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport type { TransfersStepSummaryContext } from '../model.ts'\nimport { transfersStepSummaryFromRange } from './transfersStepSummaryFromRange.ts'\n\n// the summary of amount of rewards claimed from the step reward pool by addresses\nexport async function transfersSummary(\n context: TransfersStepSummaryContext,\n): Promise<Partial<Record<Address, Partial<Record<Address, bigint>>>>> {\n return await spanRootAsync('transferSummary', async () => {\n const head = await context.head()\n const headResult = await context.store.chainMap.get(head)\n const headBoundWitness = asBlockBoundWitnessWithStorageMeta(headResult, () => `Head block not found for hash: ${context.head}`, { required: true })\n const rangeStart = isDefined(context.windowSize) ? Math.max(headBoundWitness.block - context.windowSize + 1, 0) : 0\n const ranges = deepCalculateFramesFromRange([rangeStart, headBoundWitness.block])\n const summaries = await Promise.all(ranges.map(range => transfersStepSummaryFromRange(context, range)))\n const transfers: Partial<Record<Address, Partial<Record<Address, bigint>>>> = {}\n for (let summary of summaries) {\n for (const [from, toMap] of Object.entries(summary.transfers)) {\n const validFrom = asAddress(from, () => `Invalid address: ${from}`)\n transfers[validFrom] = transfers[validFrom] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n const validTo = asAddress(to, () => `Invalid address: ${to}`)\n transfers[validFrom][validTo] = (transfers[validFrom][validTo] ?? 0n) + parseSignedBigInt(transfer)\n }\n }\n }\n return transfers\n })\n}\n","import { filterAs } from '@xylabs/array'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock, TransactionBoundWitness } from '@xyo-network/xl1-protocol'\nimport { asTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const transactionsFromHydratedBlock = (block: HydratedBlock): WithStorageMeta<TransactionBoundWitness>[] => {\n return filterAs(block[1], asTransactionBoundWitnessWithStorageMeta)\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type { ReadArchivist } from '@xyo-network/archivist-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { isBlockBoundWitnessWithStorageMeta, isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const tryHydrateBlock = async (\n archivist: ReadArchivist,\n hash: Hash,\n maxDepth: number = 1,\n): Promise<HydratedBlock | undefined> => {\n assertEx(maxDepth >= 0, () => 'maxDepth must be greater than or equal to 0')\n const bw = (await archivist.get([hash])).find(isBlockBoundWitnessWithStorageMeta)\n if (!bw) return undefined\n if (maxDepth === 0) return [bw, []]\n const blkPayloads = await archivist.get(bw.payload_hashes)\n if (maxDepth === 1) return [bw, blkPayloads]\n const transactions = blkPayloads.filter(isTransactionBoundWitnessWithStorageMeta)\n const transactionsPayloadHashes = transactions.flatMap(tx => tx.payload_hashes)\n const transactionsPayloads = await archivist.get(transactionsPayloadHashes)\n const allPayloadsHashes = new Set([...blkPayloads, ...transactionsPayloads].flatMap(p => p._hash))\n const allPayloads = await archivist.get([...allPayloadsHashes])\n const allPayloadsFiltered = allPayloads.filter(p => allPayloadsHashes.has(p._hash))\n return [bw, allPayloadsFiltered]\n}\n","import * as z from 'zod'\n\nimport { ApiConfigZod } from './Api.ts'\nimport { AppConfigZod } from './App.ts'\nimport { BridgeConfigZod } from './Bridge.ts'\nimport { ChainConfigZod } from './Chain.ts'\nimport { EvmConfigZod } from './Evm.ts'\nimport { LogConfigZod } from './Log.ts'\nimport { ProducerConfigZod } from './Producer.ts'\nimport { StorageConfigZod } from './storage/index.ts'\nimport { TelemetryConfigZod } from './Telemetry.ts'\n\nexport const Xl1CommonConfigSchema = z.object({ ...LogConfigZod.shape }).describe('XL1 common configuration options')\n\nexport const ConfigZod = z.object({\n ...Xl1CommonConfigSchema.shape,\n api: ApiConfigZod.default(ApiConfigZod.parse({})).describe('Configuration for the API node'),\n app: AppConfigZod.default(AppConfigZod.parse({})).describe('Configuration for the application'),\n bridge: BridgeConfigZod.default(BridgeConfigZod.parse({})).describe('Configuration for the Bridge node'),\n chain: ChainConfigZod.default(ChainConfigZod.parse({})).describe('Configuration for the chain'),\n evm: EvmConfigZod.default(EvmConfigZod.parse({})).describe('Configuration for EVM-backed services'),\n producer: ProducerConfigZod.default(ProducerConfigZod.parse({})).describe('Configuration for the producer'),\n storage: StorageConfigZod.default(StorageConfigZod.parse({})).describe('Configuration for the storage'),\n telemetry: TelemetryConfigZod.default(TelemetryConfigZod.parse({})).describe('Configuration for telemetry'),\n})\n\nexport type Config = z.infer<typeof ConfigZod>\n\nexport const getDefaultConfig = (): Config => ConfigZod.parse({})\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const ApiConfigZod = z.object({\n host: z.string().default('localhost').register(globalRegistry, {\n default: 'localhost',\n description: 'Host for the API',\n title: 'api.host',\n type: 'string',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the API wallet',\n title: 'api.mnemonic',\n type: 'string',\n }),\n port: z.coerce.number().default(8080).register(globalRegistry, {\n default: 8080,\n description: 'Port for the API',\n title: 'api.port',\n type: 'number',\n }),\n})\n\nexport type ApiConfig = z.infer<typeof ApiConfigZod>\n","export const isLocalhost = (hostname: string): boolean => {\n return (\n hostname === 'localhost'\n || hostname === '127.0.0.1'\n || hostname === '::1' // IPv6 localhost\n || hostname.endsWith('.localhost')\n )\n}\n","import { isLocalhost } from './isLocalhost.ts'\n\nexport const getUrl = (host: string, port: number): string => {\n const scheme = isLocalhost(host) ? 'http' : 'https'\n return `${scheme}://${host}:${port}`\n}\n","export const TODO = true\n","import * as z from 'zod'\n\n/**\n * Validates a single string containing a BIP-39 mnemonic.\n *\n * • Trims leading/trailing whitespace.\n * • Collapses any run of whitespace (spaces, tabs, new-lines) to a single space.\n * • Splits on spaces → array of words.\n * • Checks that the word-count is 12, 15, 18, 21, or 24.\n *\n */\nexport const MnemonicStringZod = z\n .string()\n .transform(s => s.trim().replaceAll(/\\s+/g, ' ')) // normalize spacing\n .refine(\n s => [12, 15, 18, 21, 24].includes(s.split(' ').length),\n { message: 'Mnemonic must contain 12, 15, 18, 21, or 24 words.' },\n ).describe('BIP-39 mnemonic string')\n\nexport type MnemonicString = z.infer<typeof MnemonicStringZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const AppConfigZod = z.object({\n port: z.coerce.number().default(3000).register(globalRegistry, {\n default: 3000,\n description: 'Port for the application',\n title: 'app.port',\n type: 'number',\n }),\n})\n\nexport type AppConfig = z.infer<typeof AppConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const BridgeConfigZod = z.object({\n host: z.string().default('localhost').register(globalRegistry, {\n default: 'localhost',\n description: 'Host for the Bridge',\n title: 'api.host',\n type: 'string',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the Bridge wallet',\n title: 'api.mnemonic',\n type: 'string',\n }),\n port: z.coerce.number().default(8081).register(globalRegistry, {\n default: 8081,\n description: 'Port for the Bridge',\n title: 'api.port',\n type: 'number',\n }),\n})\n\nexport type BridgeConfig = z.infer<typeof BridgeConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const ChainConfigZod = z.object({\n id: z.string().optional()\n .register(globalRegistry, {\n description:\n 'The unique identifier for the chain. Should be the staking contract address for contract-backed chains.',\n title: 'chain.id',\n type: 'string',\n }),\n})\n\nexport type ChainConfig = z.infer<typeof ChainConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const EvmInfuraConfigZod = z.object({\n projectId: z.string().optional().register(globalRegistry, {\n description: 'Infura project ID',\n title: 'evm.infura.projectId',\n type: 'string',\n }),\n projectSecret: z.string().optional().register(globalRegistry, {\n description: 'Infura project secret',\n title: 'evm.infura.projectSecret',\n type: 'string',\n }),\n})\n\nexport const EvmJsonRpcConfigZod = z.object({\n url: z.url().optional().register(globalRegistry, {\n description: 'JSON-RPC URL',\n title: 'evm.jsonRpc.url',\n type: 'string',\n }),\n})\n\nexport const EvmConfigZod = z.object({\n chainId: z.string().optional().register(globalRegistry, {\n description: 'EVM chain ID',\n title: 'evm.chainId',\n type: 'string',\n }),\n infura: EvmInfuraConfigZod.optional().describe('Infura Provider configuration'),\n jsonRpc: EvmJsonRpcConfigZod.optional().describe('JSON-RPC Provider configuration'),\n})\n\nexport type EvmConfig = z.infer<typeof EvmConfigZod>\n","import type { LogLevelKey } from '@xylabs/logger'\nimport { LogLevel } from '@xylabs/logger'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\nconst LogLevels = Object.keys(LogLevel) as [LogLevelKey, ...LogLevelKey[]]\n\nexport const LogConfigZod = z.object({\n logLevel: z.enum(LogLevels).default('info').register(globalRegistry, {\n choices: LogLevels,\n default: 'info',\n description: 'Desired process verbosity',\n title: 'logLevel',\n type: 'string',\n }),\n silent: z.boolean().default(false).register(globalRegistry, {\n default: false,\n description: 'Whether to run in silent mode',\n title: 'silent',\n type: 'boolean',\n }),\n})\n\nexport type LogConfig = z.infer<typeof LogConfigZod>\n","import { AddressZod, asAddress } from '@xylabs/hex'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const ProducerConfigZod = z.object({\n allowlist: z.preprocess((val) => {\n if (typeof val === 'string') {\n return val.split(',').map(s => asAddress(s.trim()))\n }\n return val\n }, z.array(AddressZod).optional().register(globalRegistry, {\n description: 'List of allowed producer addresses, if undefined anyone can participate',\n title: 'allowlist',\n type: 'array',\n })),\n\n disableIntentRedeclaration: z.boolean().optional().register(globalRegistry, {\n description: 'Should the producer skip redeclaring their intent to continue producing blocks',\n title: 'producer.disableIntentRedeclaration',\n type: 'boolean',\n }),\n // TODO: Port schema\n healthCheckPort: z.coerce.number().optional().register(globalRegistry, {\n description: 'Port for the Producer health checks',\n title: 'producer.healthCheckPort',\n type: 'number',\n }),\n heartbeatInterval: z.coerce.number().default(3_600_000).register(globalRegistry, {\n description: 'The number of milliseconds between heartbeats if no blocks are produced',\n title: 'producer.heartbeatInterval',\n type: 'number',\n }),\n // TODO: BigInt schema\n minStake: z.coerce.number().default(1).register(globalRegistry, {\n description: 'Minimum stake required to be a Producer',\n title: 'producer.minStake',\n type: 'number',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the Producer wallet',\n title: 'producer.mnemonic',\n type: 'string',\n }),\n // TODO: Port schema\n port: z.coerce.number().default(8081).register(globalRegistry, {\n default: 8081,\n description: 'Port for the Producer',\n title: 'producer.port',\n type: 'number',\n }),\n // TODO: Address schema\n rewardAddress: z.string().optional().register(globalRegistry, {\n description: 'Address to receive block rewards',\n title: 'producer.rewardAddress',\n type: 'string',\n }),\n})\n\nexport type ProducerConfig = z.infer<typeof ProducerConfigZod>\n","import { isDefined, isUndefined } from '@xylabs/typeof'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\n/**\n * Checks if the provided MongoDB configuration contains all necessary fields\n * for establishing a connection.\n * @param config MongoDB configuration object\n * @returns True if the configuration contains all necessary fields for\n * establishing a connection\n */\nexport const hasMongoConfig = (config?: MongoConfig): config is Required<MongoConfig> => {\n if (isUndefined(config)) return false\n return (\n isDefined(config.connectionString)\n && isDefined(config.database)\n && isDefined(config.domain)\n && isDefined(config.password)\n && isDefined(config.username)\n )\n}\n\nexport const MongoConfigZod = z.object({\n // TODO: Create from other arguments\n connectionString: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB connection string',\n title: 'storage.mongo.connectionString',\n type: 'string',\n }),\n database: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB database name',\n title: 'storage.mongo.database',\n type: 'string',\n }),\n domain: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB domain',\n title: 'storage.mongo.domain',\n type: 'string',\n }),\n password: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB password',\n title: 'storage.mongo.password',\n type: 'string',\n }),\n username: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB username',\n title: 'storage.mongo.username',\n type: 'string',\n }),\n})\n\nexport type MongoConfig = z.infer<typeof MongoConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MongoConfigZod } from './driver/index.ts'\n\nexport const StorageConfigZod = z.object({\n mongo: MongoConfigZod.optional().describe('Configuration for the MongoD storage driver'),\n root: z.string().optional().register(globalRegistry, {\n description: 'Root directory for local storage',\n title: 'storage.root',\n type: 'string',\n }),\n}).describe('Storage configuration options')\n\nexport type StorageConfig = z.infer<typeof StorageConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const OpenTelemetryConfigZod = z.object({\n // OpenTelemetry options\n otlpEndpoint: z.url().optional().register(globalRegistry, {\n description: 'OTLP endpoint for exporting telemetry data',\n title: 'telemetry.otel.otlpEndpoint',\n type: 'string',\n }),\n})\n\nexport const TelemetryConfigZod = z.object({\n // OpenTelemetry configuration\n otel: OpenTelemetryConfigZod.optional().describe('OpenTelemetry configuration'),\n}).describe('Telemetry configuration options')\n\nexport type TelemetryConfig = z.infer<typeof TelemetryConfigZod>\n","import * as z from 'zod'\n\nconst DescriptionSchema = z.string()\nconst TitleSchema = z.string()\n\nexport const JSONSchemaMetaSchema = z\n .object({\n id: z.string().optional(),\n title: TitleSchema.optional(),\n description: DescriptionSchema.optional(),\n deprecated: z.boolean().optional(),\n })\n .catchall(z.unknown()) // allow arbitrary extra keys\n\nexport const GlobalMetaSchema = JSONSchemaMetaSchema.extend({})\n\nconst ChoicesSchema = z\n .array(z.union([z.string(), z.number(), z.literal(true), z.undefined()]))\n .readonly()\n\nexport const UsageMetaSchema = GlobalMetaSchema.extend({\n choices: ChoicesSchema.optional(),\n default: z.unknown().optional(),\n description: DescriptionSchema,\n group: z.string().optional(),\n hidden: z.boolean().optional(),\n title: TitleSchema,\n type: z.union([\n z.literal('array'),\n z.literal('count'),\n z.literal('boolean'),\n z.literal('number'),\n z.literal('string'),\n ]),\n})\n\nexport type UsageMeta = z.infer<typeof UsageMetaSchema>\n\nexport function isUsageMeta(v: unknown): v is UsageMeta {\n return UsageMetaSchema.safeParse(v).success\n}\n","import type { Address } from '@xylabs/hex'\nimport type { JsonObject } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\n\nexport const StakeEventNames = ['StakeAdded', 'StakeRemoved', 'StakeWithdrawn'] as const\nexport type StakeEventName = typeof StakeEventNames[number]\n\nexport interface ExternalEvent<TName extends string = string, TArgs extends JsonObject = {}> {\n args: TArgs\n name: TName\n time: number // usually block number\n}\n\nexport interface EventFilter<TName extends string = string> {\n name?: TName\n time?: [number, number]\n}\n\nexport interface StakeEventArgs {\n amount: bigint\n id: number\n staked: Address\n staker: Address\n}\n\nexport type StakeEventFilterArgs = Partial<Pick<StakeEventArgs, 'staker' | 'staked'>>\n\nexport interface StakeEventFilter<TName extends StakeEventName = StakeEventName> extends EventFilter<TName> {\n args?: StakeEventFilterArgs\n}\n\nexport interface StakeEvent<TName extends StakeEventName = StakeEventName> extends ExternalEvent<TName> {\n args: StakeEventArgs\n}\n\nexport interface StakeEventsRead {\n stakeEvents<TName extends StakeEventName>(range: [number, number | 'latest'], filter?: StakeEventFilter<TName>): Promisable<StakeEvent<TName>[]>\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nexport async function addressStakeWeight(\n stakeContract: AddressStakingV2,\n staked: Address,\n by: Address,\n startEthBlock: number,\n endEthBlock: number,\n): Promise<bigint> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(`0x${XYO_NETWORK_STAKING_ADDRESS}`, by)\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, startEthBlock, endEthBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`, by)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, startEthBlock, endEthBlock)\n\n const accountStakes: Awaited<ReturnType<typeof stakeContract.getStake>> [] = []\n const accountStakeCount = await stakeContract.getStakeCountForAddress(`0x${by}`, { blockTag: startEthBlock - 1 })\n for (let i = 0; i < accountStakeCount; i++) {\n try {\n const stake = await stakeContract.getStake(`0x${by}`, i, { blockTag: startEthBlock - 1 })\n accountStakes.push(stake)\n } catch {\n break\n }\n }\n const ethStakedAddress = toAddress(staked, { prefix: false }).toLowerCase()\n const networkStakes = accountStakes.filter(s => s.staked.toLowerCase() === ethStakedAddress)\n let totalStake = 0n\n for (const stake of networkStakes) {\n totalStake += stake.amount\n }\n let totalWeight = 0n\n let addIndex = 0\n let removeIndex = 0\n\n // add up all the stakes for each block\n for (let i = startEthBlock; i <= endEthBlock; i++) {\n while (addIndex < stakeAddedEvents.length && stakeAddedEvents[addIndex]?.blockNumber === i) {\n totalStake += stakeAddedEvents[addIndex].args.amount\n addIndex++\n }\n while (removeIndex < stakeRemovedEvents.length && stakeRemovedEvents[removeIndex]?.blockNumber === i) {\n totalStake -= stakeRemovedEvents[removeIndex].args.amount\n removeIndex++\n }\n totalWeight += totalStake\n }\n return totalWeight\n}\n","import type { Address } from '@xylabs/hex'\n\nexport function claimedRewards(_address: Address) {\n return 0n\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\n\nimport { startingStakes } from './startingStakes.ts'\n\n// NOTE: Do not use the functions in this file yet, they still need to be tested\n\nexport async function stakersAsOfBlock(stakeContract: AddressStakingV2, staked: Address, ethBlock: number): Promise<Address[]> {\n const stakes = await startingStakes(stakeContract, staked, ethBlock)\n let results: Address[] = []\n for (const [address, amount] of Object.entries(stakes)) {\n if (amount > 0n) {\n results.push(toAddress(address, { prefix: false }))\n }\n }\n\n return results\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nexport async function startingStakes(stakeContract: AddressStakingV2, staked: Address, ethBlock: number): Promise<Record<Address, bigint>> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(toAddress(XYO_NETWORK_STAKING_ADDRESS, { prefix: true }))\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, 0, ethBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, 0, ethBlock)\n\n const stakes: Record<Address, bigint> = {}\n for (const event of stakeAddedEvents) {\n const by = toAddress(event.args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) + event.args.amount\n }\n for (const event of stakeRemovedEvents) {\n const by = toAddress(event.args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) - event.args.amount\n }\n\n const filteredStakes: Record<Address, bigint> = {}\n for (const [address, amount] of Object.entries(stakes) as [Address, bigint][]) {\n if (amount > 0n) {\n filteredStakes[address] = amount\n }\n }\n\n return filteredStakes\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nimport { startingStakes } from './startingStakes.ts'\n\nexport async function totalStakeWeight(stakeContract: AddressStakingV2, staked: Address, startEthBlock: number, endEthBlock: number): Promise<bigint> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, startEthBlock, endEthBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, startEthBlock, endEthBlock)\n\n const stakes = await startingStakes(stakeContract, staked, startEthBlock)\n\n let totalWeight = 0n\n let addIndex = 0\n let removeIndex = 0\n\n // add up all the stakes for each block\n for (let i = startEthBlock; i <= endEthBlock; i++) {\n while (addIndex < stakeAddedEvents.length && stakeAddedEvents[addIndex]?.blockNumber === i) {\n const by = toAddress(stakeAddedEvents[addIndex].args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) + stakeAddedEvents[addIndex].args.amount\n addIndex++\n }\n while (removeIndex < stakeRemovedEvents.length && stakeRemovedEvents[removeIndex]?.blockNumber === i) {\n const by = toAddress(stakeAddedEvents[addIndex].args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) - stakeRemovedEvents[addIndex].args.amount\n removeIndex++\n }\n totalWeight += Object.values(stakes).reduce((a, b) => a + b, 0n)\n }\n return totalWeight\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nexport function unclaimedRewards(_address: Address): Promisable<bigint> {\n throw new Error('Method not implemented.')\n}\n","import { assertEx } from '@xylabs/assert'\nimport { asTimePayload, TimeSchema } from '@xyo-network/xl1-protocol'\n\nimport { hashFromBlockNumber, hydrateBlock } from '../../block/index.ts'\nimport type { ChainContextRead } from '../../model/index.ts'\n\nexport async function xl1BlockNumberToEthBlockNumber(context: ChainContextRead, xl1BlockNumber: number): Promise<number> {\n const blockHash = await hashFromBlockNumber(context, xl1BlockNumber)\n const hydratedBlock = await hydrateBlock(context.store, blockHash)\n const timePayload = asTimePayload(hydratedBlock[1].find(p => p.schema === TimeSchema), { required: true })\n return assertEx(timePayload.ethereum, () => 'No ethereum timestamp found on block')\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Address } from '@xylabs/hex'\nimport { toHex } from '@xylabs/hex'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n ChainId,\n ExecutableFields,\n FromFields,\n SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness, TransactionBoundWitnessFields, TransactionFeesBigInt,\n} from '@xyo-network/xl1-protocol'\nimport { defaultTransactionFees } from '@xyo-network/xl1-protocol'\n\nexport async function buildTransaction(\n chain: ChainId,\n onChainPayloads: AllowedBlockPayload[],\n offChainPayloads: Payload[],\n signer: AccountInstance | AccountInstance[],\n nbf: number,\n exp: number,\n from?: Address,\n fees: TransactionFeesBigInt = defaultTransactionFees,\n): Promise<SignedHydratedTransactionWithStorageMeta> {\n if (from === undefined && Array.isArray(signer)) {\n throw new Error('from is required when signer is an array')\n }\n\n const txBoundWitnessFields: TransactionBoundWitnessFields = {\n chain,\n fees: {\n base: toHex(fees.base),\n gasLimit: toHex(fees.gasLimit),\n gasPrice: toHex(fees.gasPrice),\n priority: toHex(fees.priority),\n },\n nbf,\n exp,\n }\n\n const elevatedHashes = await PayloadBuilder.hashes(onChainPayloads)\n const script: string[] = []\n for (const elevatedHash of elevatedHashes) {\n script.push(`elevate|${elevatedHash}`)\n }\n\n const fields: TransactionBoundWitnessFields & FromFields & Partial<ExecutableFields> = {\n ...txBoundWitnessFields,\n from: from ?? (Array.isArray(signer) ? assertEx(signer.at(0)?.address) : signer.address),\n }\n\n if (script.length > 0) {\n fields.script = script\n }\n\n const [tx, txPayloads] = await new BoundWitnessBuilder<TransactionBoundWitness>()\n .fields(fields)\n .meta({ $signatures: [] })\n .payloads([...onChainPayloads, ...offChainPayloads])\n .signers(Array.isArray(signer) ? signer : [signer])\n .build()\n\n return [await PayloadBuilder.addStorageMeta(tx), await PayloadBuilder.addStorageMeta(txPayloads)]\n}\n","import type { Address } from '@xylabs/hex'\nimport { toHex } from '@xylabs/hex'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n ChainId,\n ExecutableFields,\n FromFields,\n SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness, TransactionBoundWitnessFields, TransactionFeesBigInt,\n} from '@xyo-network/xl1-protocol'\nimport { defaultTransactionFees } from '@xyo-network/xl1-protocol'\n\nexport async function buildUnsignedTransaction(\n chain: ChainId,\n onChainPayloads: AllowedBlockPayload[],\n offChainPayloads: Payload[],\n nbf: number,\n exp: number,\n from: Address,\n fees: TransactionFeesBigInt = defaultTransactionFees,\n): Promise<SignedHydratedTransactionWithStorageMeta> {\n const txBoundWitnessFields: TransactionBoundWitnessFields = {\n chain,\n fees: {\n base: toHex(fees.base),\n gasLimit: toHex(fees.gasLimit),\n gasPrice: toHex(fees.gasPrice),\n priority: toHex(fees.priority),\n },\n nbf,\n exp,\n }\n\n const elevatedHashes = await PayloadBuilder.hashes(onChainPayloads)\n const script: string[] = []\n for (const elevatedHash of elevatedHashes) {\n script.push(`elevate|${elevatedHash}`)\n }\n\n const fields: TransactionBoundWitnessFields & FromFields & Partial<ExecutableFields> = {\n ...txBoundWitnessFields,\n from,\n }\n\n if (script.length > 0) {\n fields.script = script\n }\n\n const [tx, txPayloads] = await new BoundWitnessBuilder<TransactionBoundWitness>()\n .fields(fields)\n .meta({ $signatures: [] })\n .payloads([...onChainPayloads, ...offChainPayloads])\n .build()\n\n return [await PayloadBuilder.addStorageMeta(tx), await PayloadBuilder.addStorageMeta(txPayloads)]\n}\n","import { delay } from '@xylabs/delay'\nimport type { Logger } from '@xylabs/logger'\nimport { isDefined } from '@xylabs/typeof'\nimport type { Signed } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n SignedHydratedTransaction, TransactionBoundWitness, XyoViewer,\n} from '@xyo-network/xl1-protocol'\n\nconst DEFAULT_CONFIRMATION_ATTEMPTS = 20\nconst DEFAULT_DELAY_BETWEEN_ATTEMPTS = 1000 // milliseconds\n\nexport type ConfirmSubmittedTransactionOptions = {\n /**\n * Number of attempts to confirm the transaction.\n * Defaults to 20.\n */\n attempts?: number\n /**\n * Delay in milliseconds between confirmation attempts.\n * Defaults to 1000 (1 second).\n */\n delay?: number\n /**\n * Optional logger instance for logging progress.\n */\n logger?: Logger\n}\n\n/**\n * Confirms a submitted transaction by checking if it has been included in the blockchain.\n * @param viewer The viewer\n * @param transaction The transaction to confirm\n * @param options Options for confirmation\n * @returns The confirmed transaction or throws an error if not confirmed\n */\nexport const confirmSubmittedTransaction = async (\n viewer: XyoViewer,\n transaction: Signed<TransactionBoundWitness>,\n options?: ConfirmSubmittedTransactionOptions,\n): Promise<SignedHydratedTransaction> => {\n const { attempts: maxAttempts = DEFAULT_CONFIRMATION_ATTEMPTS, delay: attemptDelay = DEFAULT_DELAY_BETWEEN_ATTEMPTS } = options || {}\n const txBWHash = await PayloadBuilder.hash(transaction)\n options?.logger?.log('🚀 confirming transaction:', txBWHash, '\\n')\n let attempts = 0\n while (true) {\n const tx = await viewer.transactionByHash(txBWHash) ?? undefined\n if (isDefined(tx)) {\n options?.logger?.log('✅ Transaction confirmed:', txBWHash, '\\n')\n return tx\n } else {\n attempts++\n if (attempts > maxAttempts) {\n options?.logger?.error(`⚠️ Transaction not confirmed after ${maxAttempts} attempts`)\n throw new Error(`Transaction ${txBWHash} not confirmed after ${maxAttempts} attempts`)\n } else {\n options?.logger?.log(`🔄 Transaction not confirmed yet, attempt ${attempts}. Retrying...`, '\\n')\n await delay(attemptDelay)\n }\n }\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport { hydrateTypedBoundWitness, tryHydrateTypedBoundWitness } from '@xyo-network/archivist-model'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n SignedHydratedTransaction, SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness,\n} from '@xyo-network/xl1-protocol'\nimport { isAllowedBlockPayload, isSignedTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport type { ChainStoreRead } from '../model/index.ts'\n\nexport const tryHydrateTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransactionWithStorageMeta | undefined> => {\n return (await tryHydrateTypedBoundWitness<TransactionBoundWitness>(\n {\n get(hashes: Hash[]) {\n return chainMap.getMany(hashes)\n },\n next() {\n throw new Error('Not implemented')\n },\n },\n hash,\n isSignedTransactionBoundWitnessWithStorageMeta,\n )) as SignedHydratedTransactionWithStorageMeta | undefined\n}\n\nexport const hydrateTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransaction> => {\n return await hydrateTypedBoundWitness<TransactionBoundWitness>(\n {\n get(hashes: Hash[]) {\n return chainMap.getMany(hashes)\n },\n next() {\n throw new Error('Not implemented')\n },\n },\n hash,\n isSignedTransactionBoundWitnessWithStorageMeta,\n ) as SignedHydratedTransaction\n}\n\nexport const flattenHydratedTransaction = (hydratedTransaction: SignedHydratedTransaction): Payload[] => {\n const [tx, txPayloads] = hydratedTransaction\n return [...txPayloads, tx]\n}\n\nexport const flattenHydratedTransactions = (hydratedTransactions: SignedHydratedTransaction[]): Payload[] =>\n hydratedTransactions.flatMap(tx => flattenHydratedTransaction(tx))\n\nexport const tryHydrateElevatedTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransactionWithStorageMeta | undefined> => {\n const hydratedTransaction = await tryHydrateTransaction({ chainMap }, hash)\n if (!hydratedTransaction) {\n return undefined\n }\n const [transaction, payloads] = hydratedTransaction\n const opCodes = (transaction.script ?? []).filter(operation => operation.startsWith('elevate|'))\n const elevatedPayloads: WithStorageMeta<AllowedBlockPayload>[] = []\n for (const opCode of opCodes) {\n const [code, hash] = opCode.split('|')\n if (code === 'elevated') {\n const elevatedPayload = payloads.find(payload => payload._hash === hash)\n if (isAllowedBlockPayload(elevatedPayload)) {\n elevatedPayloads.push(elevatedPayload)\n }\n }\n }\n if (opCodes.length === elevatedPayloads.length) {\n return [transaction, elevatedPayloads]\n }\n return undefined\n}\n\nexport const hydrateElevatedTransaction = async (\n context: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransaction> => {\n return assertEx(await tryHydrateElevatedTransaction(context, hash), () => 'Hydration failed')\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { SignedHydratedTransaction } from '@xyo-network/xl1-protocol'\n\n/** The number of bytes that a transaction and its payloads will take up in a block */\nexport function transactionBlockByteCount([transaction, payloads]: SignedHydratedTransaction): number {\n const cleanTransaction = PayloadBuilder.omitStorageMeta(transaction)\n const transactionBytes = JSON.stringify(cleanTransaction).length\n const cleanPayloads = PayloadBuilder.omitStorageMeta(payloads)\n return cleanPayloads.reduce((acc: number, payload) => acc + JSON.stringify(payload).length, 0) + transactionBytes\n}\n","import { asHash, type Hash } from '@xylabs/hex'\nimport type { Payload, WithHashStorageMeta } from '@xyo-network/payload-model'\nimport type { SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness } from '@xyo-network/xl1-protocol'\n\nimport { crackOperations } from './transactionOperations.ts'\n\nexport function transactionElevatedPayloadHashes(transaction: TransactionBoundWitness): Hash[] {\n const elevateOperations = crackOperations(transaction.script ?? []).filter(op => op[0] === 'elevate')\n return elevateOperations.map(op => asHash(op[1][0], true))\n}\n\nexport function transactionElevatedPayloads([transaction, payloads]: SignedHydratedTransactionWithStorageMeta): WithHashStorageMeta<Payload>[] {\n const hashes = transactionElevatedPayloadHashes(transaction)\n const elevatedPayloads = payloads.filter(payload => hashes.includes(payload._hash))\n return elevatedPayloads\n}\n","export function crackOperation(operation: string): [string, string[]] {\n const parts = operation.split('|')\n if (parts.length < 2) {\n throw new Error(`Invalid operation format: ${operation}`)\n }\n return [parts[0], parts.slice(1)]\n}\n\nexport function crackOperations(operations: string[]): [string, string[]][] {\n return operations.map(op => crackOperation(op))\n}\n","import type { SignedHydratedTransactionWithStorageMeta } from '@xyo-network/xl1-protocol'\nimport { AttoXL1, TransactionGasCosts } from '@xyo-network/xl1-protocol'\n\nimport { transactionBlockByteCount } from './transactionBlockByteCount.ts'\nimport { transactionElevatedPayloads } from './transactionElevatedPayloads.ts'\n\n/** The required gas for the byte storage on the block chain for a transaction */\nexport function transactionBytesRequiredGas([transaction, payloads]: SignedHydratedTransactionWithStorageMeta): AttoXL1 {\n const transactionBlockBytes = transactionBlockByteCount([transaction, payloads])\n return AttoXL1(TransactionGasCosts.characterStorage * BigInt(transactionBlockBytes))\n}\n\nexport function transactionRequiredGas(hydratedTransaction: SignedHydratedTransactionWithStorageMeta): AttoXL1 {\n const elevatedPayloads = transactionElevatedPayloads(hydratedTransaction)\n const hashes = elevatedPayloads.length + 1 /* for transaction itself */\n const signatures = hydratedTransaction[0].addresses.length\n return AttoXL1(transactionBytesRequiredGas(hydratedTransaction)\n + TransactionGasCosts.hashValidation * BigInt(hashes)\n + TransactionGasCosts.signatureValidation * BigInt(signatures)\n + TransactionGasCosts.payloadValidation * BigInt(elevatedPayloads.length))\n}\n","import { filterAs } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { asHash, type Hash } from '@xylabs/hex'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { AllowedBlockPayload, HydratedTransactionWithStorageMeta } from '@xyo-network/xl1-protocol'\nimport { isAllowedBlockPayloadWithHashStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const tryExtractElevatedHashesFromScript = (strings: string[]): Hash[] => {\n const hashes = strings\n .filter(str => str.startsWith('elevate|'))\n .map(str => str.split('|')[1])\n return filterAs(hashes, h => asHash(h))\n}\n\nexport const extractElevatedHashesFromScript = (strings: string[]): Hash[] => {\n const hashes = strings\n .filter(str => str.startsWith('elevate|'))\n .map(str => str.split('|')[1])\n const filtered = filterAs(hashes, h => asHash(h))\n assertEx(filtered.length === hashes.length, () => 'Invalid elevated hashes')\n return filtered\n}\n\nexport const tryExtractElevatedHashes = (tx: HydratedTransactionWithStorageMeta): WithStorageMeta<AllowedBlockPayload>[] => {\n const [bw, payloads] = tx\n const { script } = bw\n const hashes = script ? tryExtractElevatedHashesFromScript(script) : []\n return payloads\n .filter(p => hashes.includes(p._hash))\n .filter(isAllowedBlockPayloadWithHashStorageMeta)\n}\n\nexport const extractElevatedHashes = (tx: HydratedTransactionWithStorageMeta): WithStorageMeta<AllowedBlockPayload>[] => {\n const [bw, payloads] = tx\n const { script } = bw\n const hashes = script ? tryExtractElevatedHashesFromScript(script) : []\n const filtered = payloads\n .filter(p => hashes.includes(p._hash))\n .filter(isAllowedBlockPayloadWithHashStorageMeta)\n assertEx(filtered.length === hashes.length, () => 'Invalid elevated hashes')\n return filtered\n}\n","import { toArrayBuffer } from '@xylabs/arraybuffer'\nimport { assertEx } from '@xylabs/assert'\nimport { hexFromArrayBuffer } from '@xylabs/hex'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { Unsigned } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { TransactionBoundWitness } from '@xyo-network/xl1-protocol'\n\n/**\n * Signs an unsigned transaction with the provided account.\n * @param tx The transaction to sign\n * @param account The account to sign the transaction with\n * @returns The signed transaction\n */\nexport async function signTransaction(tx: Unsigned<TransactionBoundWitness>, account: AccountInstance) {\n assertEx(tx.from === account.address, () => 'Signer address does not match transaction from address')\n // Clone tx to prevent modifying original\n const signedTx = structuredClone(tx)\n // Update dynamic fields based on account\n signedTx.addresses = [account.address]\n signedTx.previous_hashes = [account.previousHash ?? null]\n // Calculate tx hash and sign it\n const hash = await PayloadBuilder.dataHash(signedTx)\n const hashBytes = toArrayBuffer(hash)\n const [signature] = await account.sign(hashBytes)\n // Append the signatures to the transaction\n signedTx.$signatures = [hexFromArrayBuffer(signature)]\n // Return the signed transaction\n return signedTx\n}\n","import { HDWallet } from '@xyo-network/wallet'\n\nimport { DEFAULT_WALLET_PATH } from './paths.ts'\n\n/**\n * Initializes a wallet to the default XYO path from a mnemonic phrase\n * @param walletPhrase The mnemonic phrase for the wallet\n * @returns A wallet initialized to the default XYO path using the provided phrase\n */\nexport const generateXyoBaseWalletFromPhrase = (walletPhrase: string) => {\n const wallet = HDWallet.fromPhrase(walletPhrase, DEFAULT_WALLET_PATH)\n return wallet\n}\n","export const WALLET_COMPLIANCE = '44\\'' as const\n\nexport const COIN_TYPES = { Ethereum: '60\\'' } as const\n\nexport const ACCOUNT_TYPE = { GANACHE: '0\\'', XYO: '0\\'' } as const\n\nexport const CHANGE_ADDRESS = { META_MASK: '0', XYO: '0' } as const\n\nexport const ADDRESS_INDEX = { META_MASK: '0', XYO: '0' } as const\n\nexport const DEFAULT_WALLET_PATH = `m/${WALLET_COMPLIANCE}/${COIN_TYPES.Ethereum}/${ACCOUNT_TYPE.XYO}/${CHANGE_ADDRESS.XYO}`\n"],"mappings":"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","names":["allHashesPresent","hashes","payloads","payloadHashes","Set","map","p","_hash","every","hash","has","assertEx","isTransactionBoundWitnessWithStorageMeta","blockPayloadsFromHydratedBlock","block","payload_hashes","map","hash","assertEx","find","p","_hash","filter","x","isTransactionBoundWitnessWithStorageMeta","flattenHydratedBlock","hydratedBlock","blk","blkPayloads","flattenHydratedBlocks","hydratedBlocks","flatMap","blk","flattenHydratedBlock","assertEx","isDefined","asBlockBoundWitnessWithStorageMeta","isTransactionBoundWitnessWithStorageMeta","assertEx","PayloadBuilder","isAnyPayload","StepSizes","hexToBigInt","toAddress","span","isTransfer","netBalancesForPayloads","payloads","span","balances","payload","isTransfer","from","address","amount","Object","entries","transfers","toAddress","hexToBigInt","hexToBigInt","span","isTransfer","netTransfersForPayloads","payloads","span","transfers","payload","isTransfer","from","to","amount","Object","entries","hexToBigInt","hexToBigInt","toHex","isObject","isNegativeBigInt","value","isObject","negative","isPositiveBigInt","positive","parseSignedBigInt","hexToBigInt","Error","toSignedBigInt","toHex","toPositiveBigInt","stepSize","calculateFramesFromRange","range","step","size","stepSize","start","Math","trunc","fitted","remaining","push","min","i","StepSizes","deepCalculateFramesFromRange","range","startingStep","StepSizes","length","fitted","remaining","step","newRemaining","newFittedFrames","newRemainingFrames","calculateFramesFromRange","push","i","toSorted","a","b","asHash","toSafeJsonString","asBlockBoundWitnessWithStorageMeta","StepSizes","blockFromBlockNumber","context","blockNumber","head","result","store","chainMap","get","currentBlock","asBlockBoundWitnessWithStorageMeta","required","block","jumpHash","previous","jumpBlockNumber","step","stepSize","StepSizes","entries","possibleJumpBlockNumber","asHash","step_hashes","at","newBlock","toSafeJsonString","Error","hashFromBlockNumber","context","blockNumber","blockFromBlockNumber","_hash","AsObjectFactory","isPayloadOfSchemaType","isStorageMeta","BalancesStepSummarySchema","isBalancesStepSummary","isPayloadOfSchemaType","asBalancesStepSummary","AsObjectFactory","create","isBalancesStepSummaryWithStorageMeta","value","isStorageMeta","asBalancesStepSummaryWithStorageMeta","StepSummarySchema","AsObjectFactory","isPayloadOfSchemaType","isStorageMeta","TransfersStepSummarySchema","isTransfersStepSummary","isPayloadOfSchemaType","asTransfersStepSummary","AsObjectFactory","create","isTransfersStepSummaryWithStorageMeta","value","isStorageMeta","asTransfersStepSummaryWithStorageMeta","balancesStepSummaryFromRange","context","range","frameHeadHash","hashFromBlockNumber","frameSize","head","result","undefined","hash","payloads","hydrateBlock","store","balances","address","balance","Object","entries","netBalancesForPayloads","toSignedBigInt","schema","BalancesStepSummarySchema","stepSize","step","StepSizes","indexOf","assertEx","join","summaryResult","summaryMap","get","isAnyPayload","subRanges","deepCalculateFramesFromRange","promises","map","subRange","subResults","Promise","all","bigIntBalances","subResult","parseSignedBigInt","set","finalResult","PayloadBuilder","addStorageMeta","asAddress","spanRootAsync","isDefined","asBlockBoundWitnessWithStorageMeta","balancesSummary","context","spanRootAsync","head","headResult","store","chainMap","get","headBoundWitness","asBlockBoundWitnessWithStorageMeta","required","rangeStart","isDefined","windowSize","Math","max","block","ranges","deepCalculateFramesFromRange","summaries","Promise","all","map","range","balancesStepSummaryFromRange","balances","summary","address","balance","Object","entries","validAddress","asAddress","parseSignedBigInt","isReadArchivist","obj","get","undefined","next","assertEx","PayloadBuilder","isAnyPayload","StepSizes","transfersStepSummaryFromRange","context","range","frameHeadHash","hashFromBlockNumber","frameSize","head","result","undefined","hash","payloads","hydrateBlock","store","transfers","from","toMap","Object","entries","netTransfersForPayloads","to","amount","toSignedBigInt","schema","TransfersStepSummarySchema","stepSize","step","StepSizes","indexOf","assertEx","join","summaryResult","summaryMap","get","isAnyPayload","subRanges","deepCalculateFramesFromRange","promises","map","subRange","subResults","Promise","all","bigIntBalances","subResult","transfer","parseSignedBigInt","set","finalResult","PayloadBuilder","addStorageMeta","asAddress","spanRootAsync","isDefined","asBlockBoundWitnessWithStorageMeta","transfersSummary","context","spanRootAsync","head","headResult","store","chainMap","get","headBoundWitness","asBlockBoundWitnessWithStorageMeta","required","rangeStart","isDefined","windowSize","Math","max","block","ranges","deepCalculateFramesFromRange","summaries","Promise","all","map","range","transfersStepSummaryFromRange","transfers","summary","from","toMap","Object","entries","validFrom","asAddress","to","transfer","validTo","parseSignedBigInt","readPayloadMapFromStore","store","isReadArchivist","get","hash","getMany","hashes","has","isDefined","hydrateBlock","chainMap","maxDepth","minDepth","assertEx","bw","asBlockBoundWitnessWithStorageMeta","blkPayloads","payload_hashes","allHashesPresent","transactions","filter","isTransactionBoundWitnessWithStorageMeta","transactionsPayloadHashes","flatMap","tx","transactionsPayloads","allPayloadsHashes","Set","p","_hash","allPayloads","allPayloadsFiltered","filterAs","asTransactionBoundWitnessWithStorageMeta","transactionsFromHydratedBlock","block","filterAs","asTransactionBoundWitnessWithStorageMeta","assertEx","isBlockBoundWitnessWithStorageMeta","isTransactionBoundWitnessWithStorageMeta","tryHydrateBlock","archivist","hash","maxDepth","assertEx","bw","get","find","isBlockBoundWitnessWithStorageMeta","undefined","blkPayloads","payload_hashes","transactions","filter","isTransactionBoundWitnessWithStorageMeta","transactionsPayloadHashes","flatMap","tx","transactionsPayloads","allPayloadsHashes","Set","p","_hash","allPayloads","allPayloadsFiltered","has","z","globalRegistry","z","isLocalhost","hostname","endsWith","getUrl","host","port","scheme","isLocalhost","TODO","z","MnemonicStringZod","string","transform","s","trim","replaceAll","refine","includes","split","length","message","describe","ApiConfigZod","object","host","string","default","register","globalRegistry","description","title","type","mnemonic","MnemonicStringZod","optional","port","coerce","number","globalRegistry","z","AppConfigZod","object","port","coerce","number","default","register","description","title","type","globalRegistry","z","BridgeConfigZod","object","host","string","default","register","globalRegistry","description","title","type","mnemonic","MnemonicStringZod","optional","port","coerce","number","globalRegistry","z","ChainConfigZod","object","id","string","optional","register","description","title","type","globalRegistry","z","EvmInfuraConfigZod","object","projectId","string","optional","register","description","title","type","projectSecret","EvmJsonRpcConfigZod","url","EvmConfigZod","chainId","infura","describe","jsonRpc","LogLevel","globalRegistry","z","LogLevels","Object","keys","LogConfigZod","object","logLevel","enum","default","register","choices","description","title","type","silent","boolean","AddressZod","asAddress","globalRegistry","z","ProducerConfigZod","object","allowlist","preprocess","val","split","map","s","asAddress","trim","array","AddressZod","optional","register","globalRegistry","description","title","type","disableIntentRedeclaration","boolean","healthCheckPort","coerce","number","heartbeatInterval","default","minStake","mnemonic","MnemonicStringZod","port","rewardAddress","string","isDefined","isUndefined","globalRegistry","z","hasMongoConfig","config","isUndefined","isDefined","connectionString","database","domain","password","username","MongoConfigZod","object","string","min","optional","register","globalRegistry","description","title","type","globalRegistry","z","StorageConfigZod","object","mongo","MongoConfigZod","optional","describe","root","string","register","globalRegistry","description","title","type","globalRegistry","z","OpenTelemetryConfigZod","object","otlpEndpoint","url","optional","register","description","title","type","TelemetryConfigZod","otel","describe","Xl1CommonConfigSchema","object","LogConfigZod","shape","describe","ConfigZod","api","ApiConfigZod","default","parse","app","AppConfigZod","bridge","BridgeConfigZod","chain","ChainConfigZod","evm","EvmConfigZod","producer","ProducerConfigZod","storage","StorageConfigZod","telemetry","TelemetryConfigZod","getDefaultConfig","z","DescriptionSchema","string","TitleSchema","JSONSchemaMetaSchema","object","id","optional","title","description","deprecated","boolean","catchall","unknown","GlobalMetaSchema","extend","ChoicesSchema","array","union","number","literal","undefined","readonly","UsageMetaSchema","choices","default","group","hidden","type","isUsageMeta","v","safeParse","success","StakeEventNames","toAddress","XYO_NETWORK_STAKING_ADDRESS","addressStakeWeight","stakeContract","staked","by","startEthBlock","endEthBlock","stakeAddedFilter","filters","StakeAdded","XYO_NETWORK_STAKING_ADDRESS","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","accountStakes","accountStakeCount","getStakeCountForAddress","blockTag","i","stake","getStake","push","ethStakedAddress","toAddress","prefix","toLowerCase","networkStakes","filter","s","totalStake","amount","totalWeight","addIndex","removeIndex","length","blockNumber","args","claimedRewards","_address","toAddress","toAddress","XYO_NETWORK_STAKING_ADDRESS","startingStakes","stakeContract","staked","ethBlock","stakeAddedFilter","filters","StakeAdded","toAddress","XYO_NETWORK_STAKING_ADDRESS","prefix","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","stakes","event","by","args","toLowerCase","amount","filteredStakes","address","Object","entries","stakersAsOfBlock","stakeContract","staked","ethBlock","stakes","startingStakes","results","address","amount","Object","entries","push","toAddress","prefix","toAddress","XYO_NETWORK_STAKING_ADDRESS","totalStakeWeight","stakeContract","staked","startEthBlock","endEthBlock","stakeAddedFilter","filters","StakeAdded","XYO_NETWORK_STAKING_ADDRESS","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","stakes","startingStakes","totalWeight","addIndex","removeIndex","i","length","blockNumber","by","toAddress","args","toLowerCase","prefix","amount","Object","values","reduce","a","b","unclaimedRewards","_address","Error","assertEx","asTimePayload","TimeSchema","xl1BlockNumberToEthBlockNumber","context","xl1BlockNumber","blockHash","hashFromBlockNumber","hydratedBlock","hydrateBlock","store","timePayload","asTimePayload","find","p","schema","TimeSchema","required","assertEx","ethereum","assertEx","toHex","BoundWitnessBuilder","PayloadBuilder","defaultTransactionFees","buildTransaction","chain","onChainPayloads","offChainPayloads","signer","nbf","exp","from","fees","defaultTransactionFees","undefined","Array","isArray","Error","txBoundWitnessFields","base","toHex","gasLimit","gasPrice","priority","elevatedHashes","PayloadBuilder","hashes","script","elevatedHash","push","fields","assertEx","at","address","length","tx","txPayloads","BoundWitnessBuilder","meta","$signatures","payloads","signers","build","addStorageMeta","toHex","BoundWitnessBuilder","PayloadBuilder","defaultTransactionFees","buildUnsignedTransaction","chain","onChainPayloads","offChainPayloads","nbf","exp","from","fees","defaultTransactionFees","txBoundWitnessFields","base","toHex","gasLimit","gasPrice","priority","elevatedHashes","PayloadBuilder","hashes","script","elevatedHash","push","fields","length","tx","txPayloads","BoundWitnessBuilder","meta","$signatures","payloads","build","addStorageMeta","delay","isDefined","PayloadBuilder","DEFAULT_CONFIRMATION_ATTEMPTS","DEFAULT_DELAY_BETWEEN_ATTEMPTS","confirmSubmittedTransaction","viewer","transaction","options","attempts","maxAttempts","delay","attemptDelay","txBWHash","PayloadBuilder","hash","logger","log","tx","transactionByHash","undefined","isDefined","error","Error","assertEx","hydrateTypedBoundWitness","tryHydrateTypedBoundWitness","isAllowedBlockPayload","isSignedTransactionBoundWitnessWithStorageMeta","tryHydrateTransaction","chainMap","hash","tryHydrateTypedBoundWitness","get","hashes","getMany","next","Error","isSignedTransactionBoundWitnessWithStorageMeta","hydrateTransaction","hydrateTypedBoundWitness","flattenHydratedTransaction","hydratedTransaction","tx","txPayloads","flattenHydratedTransactions","hydratedTransactions","flatMap","tryHydrateElevatedTransaction","undefined","transaction","payloads","opCodes","script","filter","operation","startsWith","elevatedPayloads","opCode","code","split","elevatedPayload","find","payload","_hash","isAllowedBlockPayload","push","length","hydrateElevatedTransaction","context","assertEx","PayloadBuilder","transactionBlockByteCount","transaction","payloads","cleanTransaction","PayloadBuilder","omitStorageMeta","transactionBytes","JSON","stringify","length","cleanPayloads","reduce","acc","payload","asHash","crackOperation","operation","parts","split","length","Error","slice","crackOperations","operations","map","op","transactionElevatedPayloadHashes","transaction","elevateOperations","crackOperations","script","filter","op","map","asHash","transactionElevatedPayloads","payloads","hashes","elevatedPayloads","payload","includes","_hash","AttoXL1","TransactionGasCosts","transactionBytesRequiredGas","transaction","payloads","transactionBlockBytes","transactionBlockByteCount","AttoXL1","TransactionGasCosts","characterStorage","BigInt","transactionRequiredGas","hydratedTransaction","elevatedPayloads","transactionElevatedPayloads","hashes","length","signatures","addresses","hashValidation","signatureValidation","payloadValidation","filterAs","assertEx","asHash","isAllowedBlockPayloadWithHashStorageMeta","tryExtractElevatedHashesFromScript","strings","hashes","filter","str","startsWith","map","split","filterAs","h","asHash","extractElevatedHashesFromScript","filtered","assertEx","length","tryExtractElevatedHashes","tx","bw","payloads","script","p","includes","_hash","isAllowedBlockPayloadWithHashStorageMeta","extractElevatedHashes","toArrayBuffer","assertEx","hexFromArrayBuffer","PayloadBuilder","signTransaction","tx","account","assertEx","from","address","signedTx","structuredClone","addresses","previous_hashes","previousHash","hash","PayloadBuilder","dataHash","hashBytes","toArrayBuffer","signature","sign","$signatures","hexFromArrayBuffer","HDWallet","WALLET_COMPLIANCE","COIN_TYPES","Ethereum","ACCOUNT_TYPE","GANACHE","XYO","CHANGE_ADDRESS","META_MASK","ADDRESS_INDEX","DEFAULT_WALLET_PATH","generateXyoBaseWalletFromPhrase","walletPhrase","wallet","HDWallet","fromPhrase","DEFAULT_WALLET_PATH"]}
|
|
1
|
+
{"version":3,"sources":["../../src/block/hydrate/allHashesPresent.ts","../../src/block/hydrate/blockPayloadsFromHydratedBlock.ts","../../src/block/hydrate/flattenHydratedBlock.ts","../../src/block/hydrate/flattenHydratedBlocks.ts","../../src/block/hydrate/hydrateBlock.ts","../../src/block/primitives/balances/balancesStepSummaryFromRange.ts","../../src/payload/netBalancesForPayloads.ts","../../src/payload/netTransfersForPayloads.ts","../../src/SignedBigInt.ts","../../src/block/primitives/frames/calculateFramesFromRange.ts","../../src/block/primitives/frames/deepCalculateFramesFromRange.ts","../../src/block/primitives/blockFromBlockNumber.ts","../../src/block/primitives/hashFromBlockNumber.ts","../../src/block/primitives/payloads/BalancesStepSummary.ts","../../src/block/primitives/payloads/StepSummary.ts","../../src/block/primitives/payloads/TransfersSummary.ts","../../src/block/primitives/balances/balancesSummary.ts","../../src/block/primitives/model.ts","../../src/block/primitives/transfers/transfersStepSummaryFromRange.ts","../../src/block/primitives/transfers/transfersSummary.ts","../../src/block/hydrate/transactionsFromHydratedBlock.ts","../../src/block/hydrate/tryHydrateBlock.ts","../../src/config/Config.ts","../../src/config/Api.ts","../../src/validation/lib/isLocalhost.ts","../../src/validation/lib/getUrl.ts","../../src/validation/schema/Address.ts","../../src/validation/schema/Mnemonic.ts","../../src/config/App.ts","../../src/config/Bridge.ts","../../src/config/Chain.ts","../../src/config/Evm.ts","../../src/config/Log.ts","../../src/config/Producer.ts","../../src/config/storage/driver/Mongo.ts","../../src/config/storage/Storage.ts","../../src/config/Telemetry.ts","../../src/config/UsageMeta.ts","../../src/model/StakeEvents.ts","../../src/steps/primitives/addressStakeWeight.ts","../../src/steps/primitives/claimedRewards.ts","../../src/steps/primitives/stakersAsOfBlock.ts","../../src/steps/primitives/startingStakes.ts","../../src/steps/primitives/totalStakeWeight.ts","../../src/steps/primitives/unclaimedRewards.ts","../../src/time/primitives/xl1BlockNumberToEthBlockNumber.ts","../../src/transaction/buildTransaction.ts","../../src/transaction/buildUnsignedTransaction.ts","../../src/transaction/confirmSubmittedTransaction.ts","../../src/transaction/hydrateTransaction.ts","../../src/transaction/primitives/transactionBlockByteCount.ts","../../src/transaction/primitives/transactionElevatedPayloads.ts","../../src/transaction/primitives/transactionOperations.ts","../../src/transaction/primitives/transactionRequiredGas.ts","../../src/transaction/script.ts","../../src/transaction/signTransaction.ts","../../src/wallet/generateXyoBaseWalletFromPhrase.ts","../../src/wallet/paths.ts"],"sourcesContent":["import type { Hash } from '@xylabs/hex'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\n\nexport function allHashesPresent(hashes: Hash[], payloads: WithStorageMeta<Payload>[]): boolean {\n const payloadHashes = new Set(payloads.map(p => p._hash))\n return hashes.every(hash => payloadHashes.has(hash))\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const blockPayloadsFromHydratedBlock = (block: HydratedBlock): WithStorageMeta<Payload>[] => {\n return block[0].payload_hashes.map(hash => assertEx(\n block[1].find(p => p._hash === hash),\n () => `missing payload ${hash}`,\n )).filter(x => !isTransactionBoundWitnessWithStorageMeta(x))\n}\n","import type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\n\nexport const flattenHydratedBlock = (hydratedBlock: HydratedBlock): WithStorageMeta<Payload>[] => {\n const [blk, blkPayloads] = hydratedBlock\n return [...blkPayloads, blk]\n}\n","import type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\n\nimport { flattenHydratedBlock } from './flattenHydratedBlock.ts'\n\nexport const flattenHydratedBlocks = (hydratedBlocks: HydratedBlock[]): WithStorageMeta<Payload>[] =>\n hydratedBlocks.flatMap(blk => flattenHydratedBlock(blk))\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport { isDefined } from '@xylabs/typeof'\nimport { type ReadArchivist } from '@xyo-network/archivist-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { asBlockBoundWitnessWithStorageMeta, isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport type { ChainStoreRead, PayloadMapRead } from '../../model/index.ts'\nimport { isReadArchivist } from '../primitives/index.ts'\nimport { allHashesPresent } from './allHashesPresent.ts'\n\nexport function readPayloadMapFromStore<T extends Payload>(store: ReadArchivist<T> | PayloadMapRead<T>): PayloadMapRead<T> {\n if (isReadArchivist(store)) {\n return {\n get: async (hash: Hash): Promise<T | undefined> => {\n return (await store.get([hash]))[0]\n },\n getMany: async (hashes: Hash[]): Promise<T[]> => {\n return (await store.get(hashes))\n },\n has: async (hash: Hash): Promise<boolean> => {\n return isDefined((await store.get([hash]))[0])\n },\n }\n }\n return store\n}\n\nexport const hydrateBlock = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n maxDepth: number = 1,\n minDepth = maxDepth,\n): Promise<HydratedBlock> => {\n assertEx(maxDepth >= 0, () => 'maxDepth must be greater than or equal to 0')\n assertEx(minDepth >= 0, () => 'minDepth must be greater than or equal to 0')\n assertEx(maxDepth >= minDepth, () => 'maxDepth must be greater than or equal to minDepth')\n\n const bw = assertEx(asBlockBoundWitnessWithStorageMeta(\n assertEx(await chainMap.get(hash), () => `block ${hash} not found`),\n ), () => `hash ${hash} is not a BlockBoundWitness`)\n\n if (maxDepth === 0) return [bw, []]\n const blkPayloads = await chainMap.getMany(bw.payload_hashes)\n if (minDepth === 1) assertEx(allHashesPresent(bw.payload_hashes, blkPayloads), () => `Unable to find all payloads for block ${hash}`)\n if (maxDepth === 1) return [bw, blkPayloads]\n const transactions = blkPayloads.filter(isTransactionBoundWitnessWithStorageMeta)\n const transactionsPayloadHashes = transactions.flatMap(tx => tx.payload_hashes)\n const transactionsPayloads = await chainMap.getMany(transactionsPayloadHashes)\n assertEx(allHashesPresent(transactionsPayloadHashes, transactionsPayloads), () => `Unable to find all payloads for transactions in block ${hash}`)\n const allPayloadsHashes = new Set([...blkPayloads, ...transactionsPayloads].flatMap(p => p._hash))\n const allPayloads = await chainMap.getMany([...allPayloadsHashes])\n const allPayloadsFiltered = allPayloads.filter(p => allPayloadsHashes.has(p._hash))\n if (maxDepth === 2) assertEx(allHashesPresent(\n [...allPayloadsHashes],\n allPayloadsFiltered,\n ), () => `Unable to find all payloads for transactions in block ${hash}`)\n return [bw, allPayloadsFiltered]\n}\n","/* eslint-disable max-statements */\nimport { assertEx } from '@xylabs/assert'\nimport { type Address } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport { netBalancesForPayloads } from '../../../payload/index.ts'\nimport {\n parseSignedBigInt, type SignedBigInt, toSignedBigInt,\n} from '../../../SignedBigInt.ts'\nimport { hydrateBlock } from '../../hydrate/index.ts'\nimport type { BlockNumberRange } from '../frames/index.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport { hashFromBlockNumber } from '../hashFromBlockNumber.ts'\nimport type { BalanceStepSummaryContext } from '../model.ts'\nimport { type BalancesStepSummary, BalancesStepSummarySchema } from '../payloads/index.ts'\n\nexport async function balancesStepSummaryFromRange(\n context: BalanceStepSummaryContext,\n range: BlockNumberRange,\n): Promise<WithStorageMeta<BalancesStepSummary>> {\n // console.log(`balanceStepSummaryFromRange: head=${head}, range=${range[0]}-${range[1]}`)\n const frameHeadHash = await hashFromBlockNumber(context, range[1])\n const frameSize = range[1] - range[0] + 1\n const head = await context.head()\n\n let result: BalancesStepSummary | undefined = undefined\n\n if (frameSize === 1) {\n const hash = await hashFromBlockNumber(context, range[0])\n const [, payloads] = await hydrateBlock(context.store, hash)\n const balances: Record<Address, SignedBigInt> = {}\n for (const [address, balance] of Object.entries(netBalancesForPayloads(payloads))) {\n balances[address as Address] = toSignedBigInt(balance)\n }\n result = {\n schema: BalancesStepSummarySchema, hash: head, stepSize: -1, balances,\n }\n } else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const step = (StepSizes as any).indexOf(frameSize)\n assertEx(step !== -1, () => `Invalid step size: ${frameSize}. Must be one of ${StepSizes.join(', ')}`)\n\n const summaryResult = await context.summaryMap.get(`${frameHeadHash}|${frameSize}`)\n if (isAnyPayload(summaryResult)) {\n result = summaryResult as WithStorageMeta<BalancesStepSummary>\n } else {\n // We do not have it, so lets build it\n await context.stepSemaphores[step].acquire()\n try {\n const subRanges = deepCalculateFramesFromRange(range, step - 1)\n const promises = subRanges.map(subRange => balancesStepSummaryFromRange(\n context,\n subRange,\n ))\n const subResults = await Promise.all(promises)\n\n // add them all up\n const bigIntBalances: Record<Address, bigint> = {}\n for (const subResult of subResults) {\n for (const [address, balance] of Object.entries(subResult.balances)) {\n bigIntBalances[address as Address] = (bigIntBalances[address as Address] ?? 0n) + parseSignedBigInt(balance)\n }\n }\n\n const balances: Record<Address, SignedBigInt> = {}\n for (const [address, balance] of Object.entries(bigIntBalances)) {\n balances[address as Address] = toSignedBigInt(balance)\n }\n\n result = {\n schema: BalancesStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, balances,\n }\n\n await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)\n } finally {\n context.stepSemaphores[step].release()\n }\n }\n }\n // console.log(`balanceStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)\n const finalResult = await PayloadBuilder.addStorageMeta(result)\n return finalResult\n}\n","import {\n type Address, type Hex, hexToBigInt, toAddress,\n} from '@xylabs/hex'\nimport { span } from '@xylabs/telemetry'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isTransfer } from '@xyo-network/xl1-protocol'\n\nexport const netBalancesForPayloads = (payloads: Payload[]) => {\n return span('netBalancesForPayloads', () => {\n const balances: Record<Address, bigint> = {}\n for (const payload of payloads) {\n if (isTransfer(payload)) {\n const { from } = payload\n for (let [address, amount] of Object.entries(payload.transfers) as [Address, Hex][]) {\n balances[toAddress(address)] = (balances[toAddress(address)] ?? 0n) + hexToBigInt(amount)\n balances[toAddress(from)] = (balances[toAddress(from)] ?? 0n) - hexToBigInt(amount)\n }\n }\n }\n return balances\n })\n}\n","import {\n type Address, type Hex, hexToBigInt,\n} from '@xylabs/hex'\nimport { span } from '@xylabs/telemetry'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isTransfer } from '@xyo-network/xl1-protocol'\n\n// the net transfer amounts for the specified accounts only\nexport function netTransfersForPayloads(payloads: Payload[]): Record<Address, Record<Address, bigint>> {\n return span('netTransfersForPayloads', () => {\n const transfers: Record<Address, Record<Address, bigint>> = {}\n for (const payload of payloads) {\n if (isTransfer(payload)) {\n const { from } = payload\n transfers[from] = transfers[from] ?? {}\n for (let [to, amount] of Object.entries(payload.transfers) as [Address, Hex][]) {\n transfers[to] = transfers[to] ?? {}\n transfers[to][from] = (transfers[to][from] ?? 0n) + hexToBigInt(amount)\n transfers[from][to] = (transfers[from][to] ?? 0n) - hexToBigInt(amount)\n }\n }\n }\n return transfers\n })\n}\n","import {\n type Hex,\n hexToBigInt,\n toHex,\n} from '@xylabs/hex'\nimport { isObject } from '@xylabs/object'\n\nexport interface NegativeBigInt {\n negative: Hex\n}\n\nexport interface PositiveBigInt {\n positive: Hex\n}\n\nexport type SignedBigInt = NegativeBigInt | PositiveBigInt\n\nexport const isNegativeBigInt = (value: unknown): value is NegativeBigInt => {\n return isObject(value) && 'negative' in value && typeof value.negative === 'string'\n}\n\nexport const isPositiveBigInt = (value: unknown): value is PositiveBigInt => {\n return isObject(value) && 'positive' in value && typeof value.positive === 'string'\n}\n\nexport const parseSignedBigInt = (value: SignedBigInt): bigint => {\n if (isNegativeBigInt(value)) {\n return -hexToBigInt(value.negative)\n } else if (isPositiveBigInt(value)) {\n return hexToBigInt(value.positive)\n } else {\n throw new Error('Invalid balance type')\n }\n}\n\nexport const toSignedBigInt = (value: bigint): SignedBigInt => {\n return value < 0n ? { negative: toHex(-value) } : { positive: toHex(value) }\n}\n\nexport const toPositiveBigInt = (value: unknown): PositiveBigInt => {\n if (isNegativeBigInt(value)) {\n return { positive: toHex(0n) }\n }\n if (isPositiveBigInt(value)) {\n return { positive: value.positive }\n }\n if (typeof value === 'bigint') {\n return { positive: toHex(value) }\n }\n throw new Error('Invalid value for positive big int')\n}\n","import { stepSize } from '@xyo-network/xl1-protocol'\n\nimport type { BlockNumberRange } from './BlockNumberRange.ts'\n\nexport function calculateFramesFromRange(range: BlockNumberRange, step: number): [\n // ranges of fitted frames\n BlockNumberRange[],\n // ranges of remaining blocks\n BlockNumberRange[]] {\n const size = stepSize(step)\n let start = (Math.trunc(range[0] / size)) * size\n const fitted: BlockNumberRange[] = []\n const remaining: BlockNumberRange[] = []\n\n // if the start is not aligned with the range, add a remaining block\n if (start !== range[0]) {\n start += size\n remaining.push([range[0], Math.min(start - 1, range[1])])\n }\n\n for (let i = start; i <= range[1]; i += size) {\n if ((i + size - 1) <= range[1]) {\n fitted.push([i, Math.min(i + size - 1, range[1])])\n } else {\n remaining.push([i, range[1]])\n }\n }\n return [fitted, remaining]\n}\n","import { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport type { BlockNumberRange } from './BlockNumberRange.ts'\nimport { calculateFramesFromRange } from './calculateFramesFromRange.ts'\n\nexport function deepCalculateFramesFromRange(range: BlockNumberRange, startingStep = StepSizes.length - 1): BlockNumberRange[] {\n const fitted: BlockNumberRange[] = []\n let remaining: BlockNumberRange[] = [range]\n\n for (let step = startingStep; step >= 0; step--) {\n const newRemaining: BlockNumberRange[] = []\n for (const range of remaining) {\n const [newFittedFrames, newRemainingFrames] = calculateFramesFromRange(range, step)\n fitted.push(...newFittedFrames)\n newRemaining.push(...newRemainingFrames)\n }\n remaining = newRemaining\n }\n\n for (const range of remaining) {\n for (let i = range[0]; i <= range[1]; i++) {\n fitted.push([i, i]) // Add individual frames for remaining ranges\n }\n }\n\n return fitted.toSorted((a, b) => a[0] - b[0]) // Sort by start of range\n}\n","import { asHash, type Hash } from '@xylabs/hex'\nimport { toSafeJsonString } from '@xylabs/object'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { BlockBoundWitness } from '@xyo-network/xl1-protocol'\nimport { asBlockBoundWitnessWithStorageMeta, StepSizes } from '@xyo-network/xl1-protocol'\n\nimport type { ChainContextRead } from '../../model/index.ts'\n\nexport async function blockFromBlockNumber(context: ChainContextRead, blockNumber: number): Promise<WithStorageMeta<BlockBoundWitness>> {\n const head = await context.head()\n const result = await context.store.chainMap.get(head)\n let currentBlock = asBlockBoundWitnessWithStorageMeta(result, () => `Head block not found for hash: ${head}`, { required: true })\n while (currentBlock.block > blockNumber) {\n let jumpHash: Hash | null = currentBlock.previous\n let jumpBlockNumber = currentBlock.block - 1\n for (const [step, stepSize] of StepSizes.entries()) {\n const possibleJumpBlockNumber = currentBlock.block - stepSize\n if (possibleJumpBlockNumber >= blockNumber && possibleJumpBlockNumber <= jumpBlockNumber) {\n jumpBlockNumber = possibleJumpBlockNumber\n jumpHash = asHash(currentBlock.step_hashes.at(step), () => `Step hash not found for step ${step} in block ${currentBlock.block}`)\n }\n }\n const newBlock = await context.store.chainMap.get(\n asHash(jumpHash, () => `Jump hash not found for block number [${blockNumber}]: ${jumpBlockNumber} ${toSafeJsonString(currentBlock, 10)}`),\n )\n currentBlock = asBlockBoundWitnessWithStorageMeta(newBlock, () => `Block not found for hash: ${jumpHash}`, { required: true })\n if (currentBlock.block === blockNumber) {\n break\n }\n if (currentBlock.block < blockNumber) {\n throw new Error(`Block number ${blockNumber} is not a valid step block number for block ${context.head}.`)\n }\n }\n return currentBlock\n}\n","import { type Hash } from '@xylabs/hex'\n\nimport type { ChainContextRead } from '../../model/index.ts'\nimport { blockFromBlockNumber } from './blockFromBlockNumber.ts'\n\nexport async function hashFromBlockNumber(context: ChainContextRead, blockNumber: number): Promise<Hash> {\n return (await blockFromBlockNumber(context, blockNumber))._hash\n}\n","import type { Address } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Schema, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType, isStorageMeta } from '@xyo-network/payload-model'\n\nimport type { SignedBigInt } from '../../../SignedBigInt.ts'\nimport type { StepSummary } from './StepSummary.ts'\n\nexport const BalancesStepSummarySchema: Schema = 'network.xyo.step.summary.balances'\nexport type BalancesStepSummarySchema = typeof BalancesStepSummarySchema\n\nexport type BalancesStepSummary = StepSummary<{\n balances: Record<Address, SignedBigInt>\n}, BalancesStepSummarySchema>\n\n/**\n * Identity function for determining if an object is an BalancesStepSummary\n */\nexport const isBalancesStepSummary = isPayloadOfSchemaType<BalancesStepSummary>(BalancesStepSummarySchema)\nexport const asBalancesStepSummary = AsObjectFactory.create<BalancesStepSummary>(isBalancesStepSummary)\n\n/**\n * Identity function for determining if an object is an BalancesStepSummary with Storage Meta\n */\nexport const isBalancesStepSummaryWithStorageMeta = (value: unknown): value is WithStorageMeta<BalancesStepSummary> => {\n return isBalancesStepSummary(value) && isStorageMeta(value)\n}\nexport const asBalancesStepSummaryWithStorageMeta = AsObjectFactory.create<WithStorageMeta<BalancesStepSummary>>(isBalancesStepSummaryWithStorageMeta)\n","import type { Hash } from '@xylabs/hex'\nimport type { EmptyObject } from '@xylabs/object'\nimport type { Payload, Schema } from '@xyo-network/payload-model'\n\nexport const StepSummarySchema: Schema = 'network.xyo.step.summary'\nexport type StepSummarySchema = typeof StepSummarySchema\n\nexport interface StepSummaryFields {\n hash: Hash // the stepHash - the hash of the last block in the step frame\n stepSize: number // the stepSize in blocks\n}\n\nexport type StepSummary<TAdditionalFields extends EmptyObject | void = void,\n TSchema extends Schema | void = void> = Payload<TAdditionalFields extends void ? StepSummaryFields : TAdditionalFields & StepSummaryFields,\n TSchema extends void ? StepSummarySchema : TSchema>\n","import type { Address } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Schema, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType, isStorageMeta } from '@xyo-network/payload-model'\n\nimport type { SignedBigInt } from '../../../SignedBigInt.ts'\nimport type { StepSummary } from './StepSummary.ts'\n\nexport const TransfersStepSummarySchema: Schema = 'network.xyo.step.summary.transfer'\nexport type TransfersStepSummarySchema = typeof TransfersStepSummarySchema\n\nexport type TransfersStepSummary = StepSummary<{\n transfers: Record<Address, Record<Address, SignedBigInt>>\n}, TransfersStepSummarySchema>\n\n/**\n * Identity function for determining if an object is an TransfersStepSummary\n */\nexport const isTransfersStepSummary = isPayloadOfSchemaType<TransfersStepSummary>(TransfersStepSummarySchema)\nexport const asTransfersStepSummary = AsObjectFactory.create<TransfersStepSummary>(isTransfersStepSummary)\n\n/**\n * Identity function for determining if an object is an TransfersStepSummary with Storage Meta\n */\nexport const isTransfersStepSummaryWithStorageMeta = (value: unknown): value is WithStorageMeta<TransfersStepSummary> => {\n return isTransfersStepSummary(value) && isStorageMeta(value)\n}\nexport const asTransfersStepSummaryWithStorageMeta\n = AsObjectFactory.create<WithStorageMeta<TransfersStepSummary>>(isTransfersStepSummaryWithStorageMeta)\n","import type { Address } from '@xylabs/hex'\nimport { asAddress } from '@xylabs/hex'\nimport { spanRootAsync } from '@xylabs/telemetry'\nimport { isDefined } from '@xylabs/typeof'\nimport { asBlockBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport { parseSignedBigInt } from '../../../SignedBigInt.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport type { BalanceStepSummaryContext } from '../model.ts'\nimport { balancesStepSummaryFromRange } from './balancesStepSummaryFromRange.ts'\n\nexport async function balancesSummary(\n context: BalanceStepSummaryContext,\n): Promise<Partial<Record<Address, bigint>>> {\n return await spanRootAsync('balanceSummary', async () => {\n const head = await context.head()\n const headResult = await context.store.chainMap.get(head)\n const headBoundWitness = asBlockBoundWitnessWithStorageMeta(headResult, () => `Head block not found for hash: ${context.head}`, { required: true })\n const rangeStart = isDefined(context.windowSize) ? Math.max(headBoundWitness.block - context.windowSize + 1, 0) : 0\n const ranges = deepCalculateFramesFromRange([rangeStart, headBoundWitness.block])\n const summaries = await Promise.all(ranges.map(range => balancesStepSummaryFromRange(context, range)))\n const balances: Partial<Record<Address, bigint>> = {}\n for (let summary of summaries) {\n for (const [address, balance] of Object.entries(summary.balances)) {\n const validAddress = asAddress(address, () => `Invalid address: ${address}`)\n balances[validAddress] = (balances[validAddress] ?? 0n) + parseSignedBigInt(balance)\n }\n }\n return balances\n })\n}\n","import type { ReadArchivist } from '@xyo-network/archivist-model'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type { Semaphore } from 'async-mutex'\n\nimport type { MapTypeRead, MapTypeWrite } from '../../map/index.ts'\nimport type { ChainContextRead } from '../../model/index.ts'\nimport type { BalancesStepSummary, TransfersStepSummary } from './payloads/index.ts'\n\nexport function isReadArchivist(obj: unknown): obj is ReadArchivist {\n return (obj as ReadArchivist).get !== undefined && (obj as ReadArchivist).next !== undefined\n}\n\nexport interface ChainSummaryContextRead<T extends Payload> extends ChainContextRead {\n stepSemaphores: Semaphore[]\n summaryMap: MapTypeRead<string, T>\n windowSize?: number\n}\n\nexport interface ChainSummaryContextWrite<T extends Payload> extends ChainContextRead {\n summaryMap: MapTypeWrite<string, T>\n}\n\nexport type ChainSummaryContext<T extends Payload> = ChainSummaryContextRead<T> & ChainSummaryContextWrite<T>\n\nexport interface BalanceStepSummaryContext extends ChainSummaryContext<BalancesStepSummary> {}\n\nexport interface TransfersStepSummaryContext extends ChainSummaryContext<TransfersStepSummary> {}\n","/* eslint-disable max-statements */\nimport { assertEx } from '@xylabs/assert'\nimport { type Address } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isAnyPayload } from '@xyo-network/payload-model'\nimport { StepSizes } from '@xyo-network/xl1-protocol'\n\nimport { netTransfersForPayloads } from '../../../payload/index.ts'\nimport {\n parseSignedBigInt, type SignedBigInt, toSignedBigInt,\n} from '../../../SignedBigInt.ts'\nimport { hydrateBlock } from '../../hydrate/index.ts'\nimport { type BlockNumberRange, deepCalculateFramesFromRange } from '../frames/index.ts'\nimport { hashFromBlockNumber } from '../hashFromBlockNumber.ts'\nimport type { TransfersStepSummaryContext } from '../model.ts'\nimport { type TransfersStepSummary, TransfersStepSummarySchema } from '../payloads/index.ts'\n\nexport async function transfersStepSummaryFromRange(\n context: TransfersStepSummaryContext,\n range: BlockNumberRange,\n): Promise<WithStorageMeta<TransfersStepSummary>> {\n // console.log(`transfersStepSummaryFromRange: head=${head}, range=${range[0]}-${range[1]}`)\n const frameHeadHash = await hashFromBlockNumber(context, range[1])\n const frameSize = range[1] - range[0] + 1\n const head = await context.head()\n\n let result: TransfersStepSummary | undefined = undefined\n\n if (frameSize === 1) {\n const hash = await hashFromBlockNumber(context, range[0])\n const [, payloads] = await hydrateBlock(context.store, hash)\n const transfers: Record<Address, Record<Address, SignedBigInt>> = {}\n for (const [from, toMap] of Object.entries(netTransfersForPayloads(payloads))) {\n transfers[from as Address] = transfers[from as Address] ?? {}\n for (const [to, amount] of Object.entries(toMap)) {\n transfers[from as Address][to as Address] = toSignedBigInt(amount)\n }\n }\n result = {\n schema: TransfersStepSummarySchema, hash: head, stepSize: -1, transfers,\n }\n } else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const step = (StepSizes as any).indexOf(frameSize)\n assertEx(step !== -1, () => `Invalid step size: ${frameSize}. Must be one of ${StepSizes.join(', ')}`)\n\n const summaryResult = await context.summaryMap.get(`${frameHeadHash}|${frameSize}`)\n if (isAnyPayload(summaryResult)) {\n result = summaryResult as WithStorageMeta<TransfersStepSummary>\n } else {\n await context.stepSemaphores[step].acquire()\n // We do not have it, so lets build it\n try {\n const subRanges = deepCalculateFramesFromRange(range, step - 1)\n const promises = subRanges.map(subRange => transfersStepSummaryFromRange(\n context,\n subRange,\n ))\n const subResults = await Promise.all(promises)\n\n // add them all up\n const bigIntBalances: Record<Address, Record<Address, bigint>> = {}\n for (const subResult of subResults) {\n for (const [from, toMap] of Object.entries(subResult.transfers)) {\n bigIntBalances[from as Address] = bigIntBalances[from as Address] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n bigIntBalances[from as Address][to as Address] = (bigIntBalances[from as Address][to as Address] ?? 0n) + parseSignedBigInt(transfer)\n }\n }\n }\n\n const transfers: Record<Address, Record<Address, SignedBigInt>> = {}\n for (const [from, toMap] of Object.entries(bigIntBalances)) {\n transfers[from as Address] = transfers[from as Address] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n transfers[from as Address][to as Address] = toSignedBigInt(transfer)\n }\n }\n\n result = {\n schema: TransfersStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, transfers,\n }\n\n await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)\n } finally {\n context.stepSemaphores[step].release()\n }\n }\n }\n // console.log(`transfersStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)\n const finalResult = await PayloadBuilder.addStorageMeta(result)\n return finalResult\n}\n","import type { Address } from '@xylabs/hex'\nimport { asAddress } from '@xylabs/hex'\nimport { spanRootAsync } from '@xylabs/telemetry'\nimport { isDefined } from '@xylabs/typeof'\nimport { asBlockBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport { parseSignedBigInt } from '../../../SignedBigInt.ts'\nimport { deepCalculateFramesFromRange } from '../frames/index.ts'\nimport type { TransfersStepSummaryContext } from '../model.ts'\nimport { transfersStepSummaryFromRange } from './transfersStepSummaryFromRange.ts'\n\n// the summary of amount of rewards claimed from the step reward pool by addresses\nexport async function transfersSummary(\n context: TransfersStepSummaryContext,\n): Promise<Partial<Record<Address, Partial<Record<Address, bigint>>>>> {\n return await spanRootAsync('transferSummary', async () => {\n const head = await context.head()\n const headResult = await context.store.chainMap.get(head)\n const headBoundWitness = asBlockBoundWitnessWithStorageMeta(headResult, () => `Head block not found for hash: ${context.head}`, { required: true })\n const rangeStart = isDefined(context.windowSize) ? Math.max(headBoundWitness.block - context.windowSize + 1, 0) : 0\n const ranges = deepCalculateFramesFromRange([rangeStart, headBoundWitness.block])\n const summaries = await Promise.all(ranges.map(range => transfersStepSummaryFromRange(context, range)))\n const transfers: Partial<Record<Address, Partial<Record<Address, bigint>>>> = {}\n for (let summary of summaries) {\n for (const [from, toMap] of Object.entries(summary.transfers)) {\n const validFrom = asAddress(from, () => `Invalid address: ${from}`)\n transfers[validFrom] = transfers[validFrom] ?? {}\n for (const [to, transfer] of Object.entries(toMap)) {\n const validTo = asAddress(to, () => `Invalid address: ${to}`)\n transfers[validFrom][validTo] = (transfers[validFrom][validTo] ?? 0n) + parseSignedBigInt(transfer)\n }\n }\n }\n return transfers\n })\n}\n","import { filterAs } from '@xylabs/array'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { HydratedBlock, TransactionBoundWitness } from '@xyo-network/xl1-protocol'\nimport { asTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const transactionsFromHydratedBlock = (block: HydratedBlock): WithStorageMeta<TransactionBoundWitness>[] => {\n return filterAs(block[1], asTransactionBoundWitnessWithStorageMeta)\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type { ReadArchivist } from '@xyo-network/archivist-model'\nimport type { HydratedBlock } from '@xyo-network/xl1-protocol'\nimport { isBlockBoundWitnessWithStorageMeta, isTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const tryHydrateBlock = async (\n archivist: ReadArchivist,\n hash: Hash,\n maxDepth: number = 1,\n): Promise<HydratedBlock | undefined> => {\n assertEx(maxDepth >= 0, () => 'maxDepth must be greater than or equal to 0')\n const bw = (await archivist.get([hash])).find(isBlockBoundWitnessWithStorageMeta)\n if (!bw) return undefined\n if (maxDepth === 0) return [bw, []]\n const blkPayloads = await archivist.get(bw.payload_hashes)\n if (maxDepth === 1) return [bw, blkPayloads]\n const transactions = blkPayloads.filter(isTransactionBoundWitnessWithStorageMeta)\n const transactionsPayloadHashes = transactions.flatMap(tx => tx.payload_hashes)\n const transactionsPayloads = await archivist.get(transactionsPayloadHashes)\n const allPayloadsHashes = new Set([...blkPayloads, ...transactionsPayloads].flatMap(p => p._hash))\n const allPayloads = await archivist.get([...allPayloadsHashes])\n const allPayloadsFiltered = allPayloads.filter(p => allPayloadsHashes.has(p._hash))\n return [bw, allPayloadsFiltered]\n}\n","import * as z from 'zod'\n\nimport { ApiConfigZod } from './Api.ts'\nimport { AppConfigZod } from './App.ts'\nimport { BridgeConfigZod } from './Bridge.ts'\nimport { ChainConfigZod } from './Chain.ts'\nimport { EvmConfigZod } from './Evm.ts'\nimport { LogConfigZod } from './Log.ts'\nimport { ProducerConfigZod } from './Producer.ts'\nimport { StorageConfigZod } from './storage/index.ts'\nimport { TelemetryConfigZod } from './Telemetry.ts'\n\nexport const Xl1CommonConfigSchema = z.object({ ...LogConfigZod.shape }).describe('XL1 common configuration options')\n\nexport const ConfigZod = z.object({\n ...Xl1CommonConfigSchema.shape,\n api: ApiConfigZod.default(ApiConfigZod.parse({})).describe('Configuration for the API node'),\n app: AppConfigZod.default(AppConfigZod.parse({})).describe('Configuration for the application'),\n bridge: BridgeConfigZod.default(BridgeConfigZod.parse({})).describe('Configuration for the Bridge node'),\n chain: ChainConfigZod.default(ChainConfigZod.parse({})).describe('Configuration for the chain'),\n evm: EvmConfigZod.default(EvmConfigZod.parse({})).describe('Configuration for EVM-backed services'),\n producer: ProducerConfigZod.default(ProducerConfigZod.parse({})).describe('Configuration for the producer'),\n storage: StorageConfigZod.default(StorageConfigZod.parse({})).describe('Configuration for the storage'),\n telemetry: TelemetryConfigZod.default(TelemetryConfigZod.parse({})).describe('Configuration for telemetry'),\n})\n\nexport type Config = z.infer<typeof ConfigZod>\n\nexport const getDefaultConfig = (): Config => ConfigZod.parse({})\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const ApiConfigZod = z.object({\n host: z.string().default('localhost').register(globalRegistry, {\n default: 'localhost',\n description: 'Host for the API',\n title: 'api.host',\n type: 'string',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the API wallet',\n title: 'api.mnemonic',\n type: 'string',\n }),\n port: z.coerce.number().default(8080).register(globalRegistry, {\n default: 8080,\n description: 'Port for the API',\n title: 'api.port',\n type: 'number',\n }),\n})\n\nexport type ApiConfig = z.infer<typeof ApiConfigZod>\n","export const isLocalhost = (hostname: string): boolean => {\n return (\n hostname === 'localhost'\n || hostname === '127.0.0.1'\n || hostname === '::1' // IPv6 localhost\n || hostname.endsWith('.localhost')\n )\n}\n","import { isLocalhost } from './isLocalhost.ts'\n\nexport const getUrl = (host: string, port: number): string => {\n const scheme = isLocalhost(host) ? 'http' : 'https'\n return `${scheme}://${host}:${port}`\n}\n","export const TODO = true\n","import * as z from 'zod'\n\n/**\n * Validates a single string containing a BIP-39 mnemonic.\n *\n * • Trims leading/trailing whitespace.\n * • Collapses any run of whitespace (spaces, tabs, new-lines) to a single space.\n * • Splits on spaces → array of words.\n * • Checks that the word-count is 12, 15, 18, 21, or 24.\n *\n */\nexport const MnemonicStringZod = z\n .string()\n .transform(s => s.trim().replaceAll(/\\s+/g, ' ')) // normalize spacing\n .refine(\n s => [12, 15, 18, 21, 24].includes(s.split(' ').length),\n { message: 'Mnemonic must contain 12, 15, 18, 21, or 24 words.' },\n ).describe('BIP-39 mnemonic string')\n\nexport type MnemonicString = z.infer<typeof MnemonicStringZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const AppConfigZod = z.object({\n port: z.coerce.number().default(3000).register(globalRegistry, {\n default: 3000,\n description: 'Port for the application',\n title: 'app.port',\n type: 'number',\n }),\n})\n\nexport type AppConfig = z.infer<typeof AppConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const BridgeConfigZod = z.object({\n host: z.string().default('localhost').register(globalRegistry, {\n default: 'localhost',\n description: 'Host for the Bridge',\n title: 'api.host',\n type: 'string',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the Bridge wallet',\n title: 'api.mnemonic',\n type: 'string',\n }),\n port: z.coerce.number().default(8081).register(globalRegistry, {\n default: 8081,\n description: 'Port for the Bridge',\n title: 'api.port',\n type: 'number',\n }),\n})\n\nexport type BridgeConfig = z.infer<typeof BridgeConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const ChainConfigZod = z.object({\n id: z.string().optional()\n .register(globalRegistry, {\n description:\n 'The unique identifier for the chain. Should be the staking contract address for contract-backed chains.',\n title: 'chain.id',\n type: 'string',\n }),\n})\n\nexport type ChainConfig = z.infer<typeof ChainConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const EvmInfuraConfigZod = z.object({\n projectId: z.string().optional().register(globalRegistry, {\n description: 'Infura project ID',\n title: 'evm.infura.projectId',\n type: 'string',\n }),\n projectSecret: z.string().optional().register(globalRegistry, {\n description: 'Infura project secret',\n title: 'evm.infura.projectSecret',\n type: 'string',\n }),\n})\n\nexport const EvmJsonRpcConfigZod = z.object({\n url: z.url().optional().register(globalRegistry, {\n description: 'JSON-RPC URL',\n title: 'evm.jsonRpc.url',\n type: 'string',\n }),\n})\n\nexport const EvmConfigZod = z.object({\n chainId: z.string().optional().register(globalRegistry, {\n description: 'EVM chain ID',\n title: 'evm.chainId',\n type: 'string',\n }),\n infura: EvmInfuraConfigZod.optional().describe('Infura Provider configuration'),\n jsonRpc: EvmJsonRpcConfigZod.optional().describe('JSON-RPC Provider configuration'),\n})\n\nexport type EvmConfig = z.infer<typeof EvmConfigZod>\n","import type { LogLevelKey } from '@xylabs/logger'\nimport { LogLevel } from '@xylabs/logger'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\nconst LogLevels = Object.keys(LogLevel) as [LogLevelKey, ...LogLevelKey[]]\n\nexport const LogConfigZod = z.object({\n logLevel: z.enum(LogLevels).default('info').register(globalRegistry, {\n choices: LogLevels,\n default: 'info',\n description: 'Desired process verbosity',\n title: 'logLevel',\n type: 'string',\n }),\n silent: z.boolean().default(false).register(globalRegistry, {\n default: false,\n description: 'Whether to run in silent mode',\n title: 'silent',\n type: 'boolean',\n }),\n})\n\nexport type LogConfig = z.infer<typeof LogConfigZod>\n","import { AddressZod, asAddress } from '@xylabs/hex'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MnemonicStringZod } from '../validation/index.ts'\n\nexport const ProducerConfigZod = z.object({\n allowlist: z.preprocess((val) => {\n if (typeof val === 'string') {\n return val.split(',').map(s => asAddress(s.trim()))\n }\n return val\n }, z.array(AddressZod).optional().register(globalRegistry, {\n description: 'List of allowed producer addresses, if undefined anyone can participate',\n title: 'allowlist',\n type: 'array',\n })),\n\n disableIntentRedeclaration: z.boolean().optional().register(globalRegistry, {\n description: 'Should the producer skip redeclaring their intent to continue producing blocks',\n title: 'producer.disableIntentRedeclaration',\n type: 'boolean',\n }),\n // TODO: Port schema\n healthCheckPort: z.coerce.number().optional().register(globalRegistry, {\n description: 'Port for the Producer health checks',\n title: 'producer.healthCheckPort',\n type: 'number',\n }),\n heartbeatInterval: z.coerce.number().default(3_600_000).register(globalRegistry, {\n description: 'The number of milliseconds between heartbeats if no blocks are produced',\n title: 'producer.heartbeatInterval',\n type: 'number',\n }),\n // TODO: BigInt schema\n minStake: z.coerce.number().default(1).register(globalRegistry, {\n description: 'Minimum stake required to be a Producer',\n title: 'producer.minStake',\n type: 'number',\n }),\n mnemonic: MnemonicStringZod.optional().register(globalRegistry, {\n description: 'Mnemonic for the Producer wallet',\n title: 'producer.mnemonic',\n type: 'string',\n }),\n // TODO: Port schema\n port: z.coerce.number().default(8081).register(globalRegistry, {\n default: 8081,\n description: 'Port for the Producer',\n title: 'producer.port',\n type: 'number',\n }),\n // TODO: Address schema\n rewardAddress: z.string().optional().register(globalRegistry, {\n description: 'Address to receive block rewards',\n title: 'producer.rewardAddress',\n type: 'string',\n }),\n})\n\nexport type ProducerConfig = z.infer<typeof ProducerConfigZod>\n","import { isDefined, isUndefined } from '@xylabs/typeof'\nimport { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\n/**\n * Checks if the provided MongoDB configuration contains all necessary fields\n * for establishing a connection.\n * @param config MongoDB configuration object\n * @returns True if the configuration contains all necessary fields for\n * establishing a connection\n */\nexport const hasMongoConfig = (config?: MongoConfig): config is Required<MongoConfig> => {\n if (isUndefined(config)) return false\n return (\n isDefined(config.connectionString)\n && isDefined(config.database)\n && isDefined(config.domain)\n && isDefined(config.password)\n && isDefined(config.username)\n )\n}\n\nexport const MongoConfigZod = z.object({\n // TODO: Create from other arguments\n connectionString: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB connection string',\n title: 'storage.mongo.connectionString',\n type: 'string',\n }),\n database: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB database name',\n title: 'storage.mongo.database',\n type: 'string',\n }),\n domain: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB domain',\n title: 'storage.mongo.domain',\n type: 'string',\n }),\n password: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB password',\n title: 'storage.mongo.password',\n type: 'string',\n }),\n username: z.string().min(1).optional().register(globalRegistry, {\n description: 'MongoDB username',\n title: 'storage.mongo.username',\n type: 'string',\n }),\n})\n\nexport type MongoConfig = z.infer<typeof MongoConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nimport { MongoConfigZod } from './driver/index.ts'\n\nexport const StorageConfigZod = z.object({\n mongo: MongoConfigZod.optional().describe('Configuration for the MongoD storage driver'),\n root: z.string().optional().register(globalRegistry, {\n description: 'Root directory for local storage',\n title: 'storage.root',\n type: 'string',\n }),\n}).describe('Storage configuration options')\n\nexport type StorageConfig = z.infer<typeof StorageConfigZod>\n","import { globalRegistry } from 'zod'\nimport * as z from 'zod'\n\nexport const OpenTelemetryConfigZod = z.object({\n // OpenTelemetry options\n otlpEndpoint: z.url().optional().register(globalRegistry, {\n description: 'OTLP endpoint for exporting telemetry data',\n title: 'telemetry.otel.otlpEndpoint',\n type: 'string',\n }),\n})\n\nexport const TelemetryConfigZod = z.object({\n // OpenTelemetry configuration\n otel: OpenTelemetryConfigZod.optional().describe('OpenTelemetry configuration'),\n}).describe('Telemetry configuration options')\n\nexport type TelemetryConfig = z.infer<typeof TelemetryConfigZod>\n","import * as z from 'zod'\n\nconst DescriptionSchema = z.string()\nconst TitleSchema = z.string()\n\nexport const JSONSchemaMetaSchema = z\n .object({\n id: z.string().optional(),\n title: TitleSchema.optional(),\n description: DescriptionSchema.optional(),\n deprecated: z.boolean().optional(),\n })\n .catchall(z.unknown()) // allow arbitrary extra keys\n\nexport const GlobalMetaSchema = JSONSchemaMetaSchema.extend({})\n\nconst ChoicesSchema = z\n .array(z.union([z.string(), z.number(), z.literal(true), z.undefined()]))\n .readonly()\n\nexport const UsageMetaSchema = GlobalMetaSchema.extend({\n choices: ChoicesSchema.optional(),\n default: z.unknown().optional(),\n description: DescriptionSchema,\n group: z.string().optional(),\n hidden: z.boolean().optional(),\n title: TitleSchema,\n type: z.union([\n z.literal('array'),\n z.literal('count'),\n z.literal('boolean'),\n z.literal('number'),\n z.literal('string'),\n ]),\n})\n\nexport type UsageMeta = z.infer<typeof UsageMetaSchema>\n\nexport function isUsageMeta(v: unknown): v is UsageMeta {\n return UsageMetaSchema.safeParse(v).success\n}\n","import type { Address } from '@xylabs/hex'\nimport type { JsonObject } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\n\nexport const StakeEventNames = ['StakeAdded', 'StakeRemoved', 'StakeWithdrawn'] as const\nexport type StakeEventName = typeof StakeEventNames[number]\n\nexport interface ExternalEvent<TName extends string = string, TArgs extends JsonObject = {}> {\n args: TArgs\n name: TName\n time: number // usually block number\n}\n\nexport interface EventFilter<TName extends string = string> {\n name?: TName\n time?: [number, number]\n}\n\nexport interface StakeEventArgs {\n amount: bigint\n id: number\n staked: Address\n staker: Address\n}\n\nexport type StakeEventFilterArgs = Partial<Pick<StakeEventArgs, 'staker' | 'staked'>>\n\nexport interface StakeEventFilter<TName extends StakeEventName = StakeEventName> extends EventFilter<TName> {\n args?: StakeEventFilterArgs\n}\n\nexport interface StakeEvent<TName extends StakeEventName = StakeEventName> extends ExternalEvent<TName> {\n args: StakeEventArgs\n}\n\nexport interface StakeEventsRead {\n stakeEvents<TName extends StakeEventName>(range: [number, number | 'latest'], filter?: StakeEventFilter<TName>): Promisable<StakeEvent<TName>[]>\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nexport async function addressStakeWeight(\n stakeContract: AddressStakingV2,\n staked: Address,\n by: Address,\n startEthBlock: number,\n endEthBlock: number,\n): Promise<bigint> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(`0x${XYO_NETWORK_STAKING_ADDRESS}`, by)\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, startEthBlock, endEthBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`, by)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, startEthBlock, endEthBlock)\n\n const accountStakes: Awaited<ReturnType<typeof stakeContract.getStake>> [] = []\n const accountStakeCount = await stakeContract.getStakeCountForAddress(`0x${by}`, { blockTag: startEthBlock - 1 })\n for (let i = 0; i < accountStakeCount; i++) {\n try {\n const stake = await stakeContract.getStake(`0x${by}`, i, { blockTag: startEthBlock - 1 })\n accountStakes.push(stake)\n } catch {\n break\n }\n }\n const ethStakedAddress = toAddress(staked, { prefix: false }).toLowerCase()\n const networkStakes = accountStakes.filter(s => s.staked.toLowerCase() === ethStakedAddress)\n let totalStake = 0n\n for (const stake of networkStakes) {\n totalStake += stake.amount\n }\n let totalWeight = 0n\n let addIndex = 0\n let removeIndex = 0\n\n // add up all the stakes for each block\n for (let i = startEthBlock; i <= endEthBlock; i++) {\n while (addIndex < stakeAddedEvents.length && stakeAddedEvents[addIndex]?.blockNumber === i) {\n totalStake += stakeAddedEvents[addIndex].args.amount\n addIndex++\n }\n while (removeIndex < stakeRemovedEvents.length && stakeRemovedEvents[removeIndex]?.blockNumber === i) {\n totalStake -= stakeRemovedEvents[removeIndex].args.amount\n removeIndex++\n }\n totalWeight += totalStake\n }\n return totalWeight\n}\n","import type { Address } from '@xylabs/hex'\n\nexport function claimedRewards(_address: Address) {\n return 0n\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\n\nimport { startingStakes } from './startingStakes.ts'\n\n// NOTE: Do not use the functions in this file yet, they still need to be tested\n\nexport async function stakersAsOfBlock(stakeContract: AddressStakingV2, staked: Address, ethBlock: number): Promise<Address[]> {\n const stakes = await startingStakes(stakeContract, staked, ethBlock)\n let results: Address[] = []\n for (const [address, amount] of Object.entries(stakes)) {\n if (amount > 0n) {\n results.push(toAddress(address, { prefix: false }))\n }\n }\n\n return results\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nexport async function startingStakes(stakeContract: AddressStakingV2, staked: Address, ethBlock: number): Promise<Record<Address, bigint>> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(toAddress(XYO_NETWORK_STAKING_ADDRESS, { prefix: true }))\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, 0, ethBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, 0, ethBlock)\n\n const stakes: Record<Address, bigint> = {}\n for (const event of stakeAddedEvents) {\n const by = toAddress(event.args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) + event.args.amount\n }\n for (const event of stakeRemovedEvents) {\n const by = toAddress(event.args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) - event.args.amount\n }\n\n const filteredStakes: Record<Address, bigint> = {}\n for (const [address, amount] of Object.entries(stakes) as [Address, bigint][]) {\n if (amount > 0n) {\n filteredStakes[address] = amount\n }\n }\n\n return filteredStakes\n}\n","import { type Address, toAddress } from '@xylabs/hex'\nimport type { AddressStakingV2 } from '@xyo-network/typechain'\nimport { XYO_NETWORK_STAKING_ADDRESS } from '@xyo-network/xl1-protocol'\n\nimport { startingStakes } from './startingStakes.ts'\n\nexport async function totalStakeWeight(stakeContract: AddressStakingV2, staked: Address, startEthBlock: number, endEthBlock: number): Promise<bigint> {\n const stakeAddedFilter = stakeContract.filters.StakeAdded(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeAddedEvents = await stakeContract.queryFilter(stakeAddedFilter, startEthBlock, endEthBlock)\n\n const stakeRemovedFilter = stakeContract.filters.StakeRemoved(`0x${XYO_NETWORK_STAKING_ADDRESS}`)\n const stakeRemovedEvents = await stakeContract.queryFilter(stakeRemovedFilter, startEthBlock, endEthBlock)\n\n const stakes = await startingStakes(stakeContract, staked, startEthBlock)\n\n let totalWeight = 0n\n let addIndex = 0\n let removeIndex = 0\n\n // add up all the stakes for each block\n for (let i = startEthBlock; i <= endEthBlock; i++) {\n while (addIndex < stakeAddedEvents.length && stakeAddedEvents[addIndex]?.blockNumber === i) {\n const by = toAddress(stakeAddedEvents[addIndex].args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) + stakeAddedEvents[addIndex].args.amount\n addIndex++\n }\n while (removeIndex < stakeRemovedEvents.length && stakeRemovedEvents[removeIndex]?.blockNumber === i) {\n const by = toAddress(stakeAddedEvents[addIndex].args.by.toLowerCase(), { prefix: false })\n stakes[by] = (stakes[by] ?? 0n) - stakeRemovedEvents[addIndex].args.amount\n removeIndex++\n }\n totalWeight += Object.values(stakes).reduce((a, b) => a + b, 0n)\n }\n return totalWeight\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nexport function unclaimedRewards(_address: Address): Promisable<bigint> {\n throw new Error('Method not implemented.')\n}\n","import { assertEx } from '@xylabs/assert'\nimport { asTimePayload, TimeSchema } from '@xyo-network/xl1-protocol'\n\nimport { hashFromBlockNumber, hydrateBlock } from '../../block/index.ts'\nimport type { ChainContextRead } from '../../model/index.ts'\n\nexport async function xl1BlockNumberToEthBlockNumber(context: ChainContextRead, xl1BlockNumber: number): Promise<number> {\n const blockHash = await hashFromBlockNumber(context, xl1BlockNumber)\n const hydratedBlock = await hydrateBlock(context.store, blockHash)\n const timePayload = asTimePayload(hydratedBlock[1].find(p => p.schema === TimeSchema), { required: true })\n return assertEx(timePayload.ethereum, () => 'No ethereum timestamp found on block')\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Address } from '@xylabs/hex'\nimport { toHex } from '@xylabs/hex'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n ChainId,\n ExecutableFields,\n FromFields,\n SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness, TransactionBoundWitnessFields, TransactionFeesBigInt,\n} from '@xyo-network/xl1-protocol'\nimport { defaultTransactionFees } from '@xyo-network/xl1-protocol'\n\nexport async function buildTransaction(\n chain: ChainId,\n onChainPayloads: AllowedBlockPayload[],\n offChainPayloads: Payload[],\n signer: AccountInstance | AccountInstance[],\n nbf: number,\n exp: number,\n from?: Address,\n fees: TransactionFeesBigInt = defaultTransactionFees,\n): Promise<SignedHydratedTransactionWithStorageMeta> {\n if (from === undefined && Array.isArray(signer)) {\n throw new Error('from is required when signer is an array')\n }\n\n const txBoundWitnessFields: TransactionBoundWitnessFields = {\n chain,\n fees: {\n base: toHex(fees.base),\n gasLimit: toHex(fees.gasLimit),\n gasPrice: toHex(fees.gasPrice),\n priority: toHex(fees.priority),\n },\n nbf,\n exp,\n }\n\n const elevatedHashes = await PayloadBuilder.hashes(onChainPayloads)\n const script: string[] = []\n for (const elevatedHash of elevatedHashes) {\n script.push(`elevate|${elevatedHash}`)\n }\n\n const fields: TransactionBoundWitnessFields & FromFields & Partial<ExecutableFields> = {\n ...txBoundWitnessFields,\n from: from ?? (Array.isArray(signer) ? assertEx(signer.at(0)?.address) : signer.address),\n }\n\n if (script.length > 0) {\n fields.script = script\n }\n\n const [tx, txPayloads] = await new BoundWitnessBuilder<TransactionBoundWitness>()\n .fields(fields)\n .meta({ $signatures: [] })\n .payloads([...onChainPayloads, ...offChainPayloads])\n .signers(Array.isArray(signer) ? signer : [signer])\n .build()\n\n return [await PayloadBuilder.addStorageMeta(tx), await PayloadBuilder.addStorageMeta(txPayloads)]\n}\n","import type { Address } from '@xylabs/hex'\nimport { toHex } from '@xylabs/hex'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n ChainId,\n ExecutableFields,\n FromFields,\n SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness, TransactionBoundWitnessFields, TransactionFeesBigInt,\n} from '@xyo-network/xl1-protocol'\nimport { defaultTransactionFees } from '@xyo-network/xl1-protocol'\n\nexport async function buildUnsignedTransaction(\n chain: ChainId,\n onChainPayloads: AllowedBlockPayload[],\n offChainPayloads: Payload[],\n nbf: number,\n exp: number,\n from: Address,\n fees: TransactionFeesBigInt = defaultTransactionFees,\n): Promise<SignedHydratedTransactionWithStorageMeta> {\n const txBoundWitnessFields: TransactionBoundWitnessFields = {\n chain,\n fees: {\n base: toHex(fees.base),\n gasLimit: toHex(fees.gasLimit),\n gasPrice: toHex(fees.gasPrice),\n priority: toHex(fees.priority),\n },\n nbf,\n exp,\n }\n\n const elevatedHashes = await PayloadBuilder.hashes(onChainPayloads)\n const script: string[] = []\n for (const elevatedHash of elevatedHashes) {\n script.push(`elevate|${elevatedHash}`)\n }\n\n const fields: TransactionBoundWitnessFields & FromFields & Partial<ExecutableFields> = {\n ...txBoundWitnessFields,\n from,\n }\n\n if (script.length > 0) {\n fields.script = script\n }\n\n const [tx, txPayloads] = await new BoundWitnessBuilder<TransactionBoundWitness>()\n .fields(fields)\n .meta({ $signatures: [] })\n .payloads([...onChainPayloads, ...offChainPayloads])\n .build()\n\n return [await PayloadBuilder.addStorageMeta(tx), await PayloadBuilder.addStorageMeta(txPayloads)]\n}\n","import { delay } from '@xylabs/delay'\nimport type { Logger } from '@xylabs/logger'\nimport { isDefined } from '@xylabs/typeof'\nimport type { Signed } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n SignedHydratedTransaction, TransactionBoundWitness, XyoViewer,\n} from '@xyo-network/xl1-protocol'\n\nconst DEFAULT_CONFIRMATION_ATTEMPTS = 20\nconst DEFAULT_DELAY_BETWEEN_ATTEMPTS = 1000 // milliseconds\n\nexport type ConfirmSubmittedTransactionOptions = {\n /**\n * Number of attempts to confirm the transaction.\n * Defaults to 20.\n */\n attempts?: number\n /**\n * Delay in milliseconds between confirmation attempts.\n * Defaults to 1000 (1 second).\n */\n delay?: number\n /**\n * Optional logger instance for logging progress.\n */\n logger?: Logger\n}\n\n/**\n * Confirms a submitted transaction by checking if it has been included in the blockchain.\n * @param viewer The viewer\n * @param transaction The transaction to confirm\n * @param options Options for confirmation\n * @returns The confirmed transaction or throws an error if not confirmed\n */\nexport const confirmSubmittedTransaction = async (\n viewer: XyoViewer,\n transaction: Signed<TransactionBoundWitness>,\n options?: ConfirmSubmittedTransactionOptions,\n): Promise<SignedHydratedTransaction> => {\n const { attempts: maxAttempts = DEFAULT_CONFIRMATION_ATTEMPTS, delay: attemptDelay = DEFAULT_DELAY_BETWEEN_ATTEMPTS } = options || {}\n const txBWHash = await PayloadBuilder.hash(transaction)\n options?.logger?.log('🚀 confirming transaction:', txBWHash, '\\n')\n let attempts = 0\n while (true) {\n const tx = await viewer.transactionByHash(txBWHash) ?? undefined\n if (isDefined(tx)) {\n options?.logger?.log('✅ Transaction confirmed:', txBWHash, '\\n')\n return tx\n } else {\n attempts++\n if (attempts > maxAttempts) {\n options?.logger?.error(`⚠️ Transaction not confirmed after ${maxAttempts} attempts`)\n throw new Error(`Transaction ${txBWHash} not confirmed after ${maxAttempts} attempts`)\n } else {\n options?.logger?.log(`🔄 Transaction not confirmed yet, attempt ${attempts}. Retrying...`, '\\n')\n await delay(attemptDelay)\n }\n }\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport { hydrateTypedBoundWitness, tryHydrateTypedBoundWitness } from '@xyo-network/archivist-model'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport type {\n AllowedBlockPayload,\n SignedHydratedTransaction, SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness,\n} from '@xyo-network/xl1-protocol'\nimport { isAllowedBlockPayload, isSignedTransactionBoundWitnessWithStorageMeta } from '@xyo-network/xl1-protocol'\n\nimport type { ChainStoreRead } from '../model/index.ts'\n\nexport const tryHydrateTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransactionWithStorageMeta | undefined> => {\n return (await tryHydrateTypedBoundWitness<TransactionBoundWitness>(\n {\n get(hashes: Hash[]) {\n return chainMap.getMany(hashes)\n },\n next() {\n throw new Error('Not implemented')\n },\n },\n hash,\n isSignedTransactionBoundWitnessWithStorageMeta,\n )) as SignedHydratedTransactionWithStorageMeta | undefined\n}\n\nexport const hydrateTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransaction> => {\n return await hydrateTypedBoundWitness<TransactionBoundWitness>(\n {\n get(hashes: Hash[]) {\n return chainMap.getMany(hashes)\n },\n next() {\n throw new Error('Not implemented')\n },\n },\n hash,\n isSignedTransactionBoundWitnessWithStorageMeta,\n ) as SignedHydratedTransaction\n}\n\nexport const flattenHydratedTransaction = (hydratedTransaction: SignedHydratedTransaction): Payload[] => {\n const [tx, txPayloads] = hydratedTransaction\n return [...txPayloads, tx]\n}\n\nexport const flattenHydratedTransactions = (hydratedTransactions: SignedHydratedTransaction[]): Payload[] =>\n hydratedTransactions.flatMap(tx => flattenHydratedTransaction(tx))\n\nexport const tryHydrateElevatedTransaction = async (\n { chainMap }: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransactionWithStorageMeta | undefined> => {\n const hydratedTransaction = await tryHydrateTransaction({ chainMap }, hash)\n if (!hydratedTransaction) {\n return undefined\n }\n const [transaction, payloads] = hydratedTransaction\n const opCodes = (transaction.script ?? []).filter(operation => operation.startsWith('elevate|'))\n const elevatedPayloads: WithStorageMeta<AllowedBlockPayload>[] = []\n for (const opCode of opCodes) {\n const [code, hash] = opCode.split('|')\n if (code === 'elevated') {\n const elevatedPayload = payloads.find(payload => payload._hash === hash)\n if (isAllowedBlockPayload(elevatedPayload)) {\n elevatedPayloads.push(elevatedPayload)\n }\n }\n }\n if (opCodes.length === elevatedPayloads.length) {\n return [transaction, elevatedPayloads]\n }\n return undefined\n}\n\nexport const hydrateElevatedTransaction = async (\n context: ChainStoreRead,\n hash: Hash,\n): Promise<SignedHydratedTransaction> => {\n return assertEx(await tryHydrateElevatedTransaction(context, hash), () => 'Hydration failed')\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { SignedHydratedTransaction } from '@xyo-network/xl1-protocol'\n\n/** The number of bytes that a transaction and its payloads will take up in a block */\nexport function transactionBlockByteCount([transaction, payloads]: SignedHydratedTransaction): number {\n const cleanTransaction = PayloadBuilder.omitStorageMeta(transaction)\n const transactionBytes = JSON.stringify(cleanTransaction).length\n const cleanPayloads = PayloadBuilder.omitStorageMeta(payloads)\n return cleanPayloads.reduce((acc: number, payload) => acc + JSON.stringify(payload).length, 0) + transactionBytes\n}\n","import { asHash, type Hash } from '@xylabs/hex'\nimport type { Payload, WithHashStorageMeta } from '@xyo-network/payload-model'\nimport type { SignedHydratedTransactionWithStorageMeta, TransactionBoundWitness } from '@xyo-network/xl1-protocol'\n\nimport { crackOperations } from './transactionOperations.ts'\n\nexport function transactionElevatedPayloadHashes(transaction: TransactionBoundWitness): Hash[] {\n const elevateOperations = crackOperations(transaction.script ?? []).filter(op => op[0] === 'elevate')\n return elevateOperations.map(op => asHash(op[1][0], true))\n}\n\nexport function transactionElevatedPayloads([transaction, payloads]: SignedHydratedTransactionWithStorageMeta): WithHashStorageMeta<Payload>[] {\n const hashes = transactionElevatedPayloadHashes(transaction)\n const elevatedPayloads = payloads.filter(payload => hashes.includes(payload._hash))\n return elevatedPayloads\n}\n","export function crackOperation(operation: string): [string, string[]] {\n const parts = operation.split('|')\n if (parts.length < 2) {\n throw new Error(`Invalid operation format: ${operation}`)\n }\n return [parts[0], parts.slice(1)]\n}\n\nexport function crackOperations(operations: string[]): [string, string[]][] {\n return operations.map(op => crackOperation(op))\n}\n","import type { SignedHydratedTransactionWithStorageMeta } from '@xyo-network/xl1-protocol'\nimport { AttoXL1, TransactionGasCosts } from '@xyo-network/xl1-protocol'\n\nimport { transactionBlockByteCount } from './transactionBlockByteCount.ts'\nimport { transactionElevatedPayloads } from './transactionElevatedPayloads.ts'\n\n/** The required gas for the byte storage on the block chain for a transaction */\nexport function transactionBytesRequiredGas([transaction, payloads]: SignedHydratedTransactionWithStorageMeta): AttoXL1 {\n const transactionBlockBytes = transactionBlockByteCount([transaction, payloads])\n return AttoXL1(TransactionGasCosts.characterStorage * BigInt(transactionBlockBytes))\n}\n\nexport function transactionRequiredGas(hydratedTransaction: SignedHydratedTransactionWithStorageMeta): AttoXL1 {\n const elevatedPayloads = transactionElevatedPayloads(hydratedTransaction)\n const hashes = elevatedPayloads.length + 1 /* for transaction itself */\n const signatures = hydratedTransaction[0].addresses.length\n return AttoXL1(transactionBytesRequiredGas(hydratedTransaction)\n + TransactionGasCosts.hashValidation * BigInt(hashes)\n + TransactionGasCosts.signatureValidation * BigInt(signatures)\n + TransactionGasCosts.payloadValidation * BigInt(elevatedPayloads.length))\n}\n","import { filterAs } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { asHash, type Hash } from '@xylabs/hex'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport type { AllowedBlockPayload, HydratedTransactionWithStorageMeta } from '@xyo-network/xl1-protocol'\nimport { isAllowedBlockPayloadWithHashStorageMeta } from '@xyo-network/xl1-protocol'\n\nexport const tryExtractElevatedHashesFromScript = (strings: string[]): Hash[] => {\n const hashes = strings\n .filter(str => str.startsWith('elevate|'))\n .map(str => str.split('|')[1])\n return filterAs(hashes, h => asHash(h))\n}\n\nexport const extractElevatedHashesFromScript = (strings: string[]): Hash[] => {\n const hashes = strings\n .filter(str => str.startsWith('elevate|'))\n .map(str => str.split('|')[1])\n const filtered = filterAs(hashes, h => asHash(h))\n assertEx(filtered.length === hashes.length, () => 'Invalid elevated hashes')\n return filtered\n}\n\nexport const tryExtractElevatedHashes = (tx: HydratedTransactionWithStorageMeta): WithStorageMeta<AllowedBlockPayload>[] => {\n const [bw, payloads] = tx\n const { script } = bw\n const hashes = script ? tryExtractElevatedHashesFromScript(script) : []\n return payloads\n .filter(p => hashes.includes(p._hash))\n .filter(isAllowedBlockPayloadWithHashStorageMeta)\n}\n\nexport const extractElevatedHashes = (tx: HydratedTransactionWithStorageMeta): WithStorageMeta<AllowedBlockPayload>[] => {\n const [bw, payloads] = tx\n const { script } = bw\n const hashes = script ? tryExtractElevatedHashesFromScript(script) : []\n const filtered = payloads\n .filter(p => hashes.includes(p._hash))\n .filter(isAllowedBlockPayloadWithHashStorageMeta)\n assertEx(filtered.length === hashes.length, () => 'Invalid elevated hashes')\n return filtered\n}\n","import { toArrayBuffer } from '@xylabs/arraybuffer'\nimport { assertEx } from '@xylabs/assert'\nimport { hexFromArrayBuffer } from '@xylabs/hex'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { Unsigned } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { TransactionBoundWitness } from '@xyo-network/xl1-protocol'\n\n/**\n * Signs an unsigned transaction with the provided account.\n * @param tx The transaction to sign\n * @param account The account to sign the transaction with\n * @returns The signed transaction\n */\nexport async function signTransaction(tx: Unsigned<TransactionBoundWitness>, account: AccountInstance) {\n assertEx(tx.from === account.address, () => 'Signer address does not match transaction from address')\n // Clone tx to prevent modifying original\n const signedTx = structuredClone(tx)\n // Update dynamic fields based on account\n signedTx.addresses = [account.address]\n signedTx.previous_hashes = [account.previousHash ?? null]\n // Calculate tx hash and sign it\n const hash = await PayloadBuilder.dataHash(signedTx)\n const hashBytes = toArrayBuffer(hash)\n const [signature] = await account.sign(hashBytes)\n // Append the signatures to the transaction\n signedTx.$signatures = [hexFromArrayBuffer(signature)]\n // Return the signed transaction\n return signedTx\n}\n","import { HDWallet } from '@xyo-network/wallet'\n\nimport { DEFAULT_WALLET_PATH } from './paths.ts'\n\n/**\n * Initializes a wallet to the default XYO path from a mnemonic phrase\n * @param walletPhrase The mnemonic phrase for the wallet\n * @returns A wallet initialized to the default XYO path using the provided phrase\n */\nexport const generateXyoBaseWalletFromPhrase = (walletPhrase: string) => {\n const wallet = HDWallet.fromPhrase(walletPhrase, DEFAULT_WALLET_PATH)\n return wallet\n}\n","export const WALLET_COMPLIANCE = '44\\'' as const\n\nexport const COIN_TYPES = { Ethereum: '60\\'' } as const\n\nexport const ACCOUNT_TYPE = { GANACHE: '0\\'', XYO: '0\\'' } as const\n\nexport const CHANGE_ADDRESS = { META_MASK: '0', XYO: '0' } as const\n\nexport const ADDRESS_INDEX = { META_MASK: '0', XYO: '0' } as const\n\nexport const DEFAULT_WALLET_PATH = `m/${WALLET_COMPLIANCE}/${COIN_TYPES.Ethereum}/${ACCOUNT_TYPE.XYO}/${CHANGE_ADDRESS.XYO}`\n"],"mappings":"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","names":["allHashesPresent","hashes","payloads","payloadHashes","Set","map","p","_hash","every","hash","has","assertEx","isTransactionBoundWitnessWithStorageMeta","blockPayloadsFromHydratedBlock","block","payload_hashes","map","hash","assertEx","find","p","_hash","filter","x","isTransactionBoundWitnessWithStorageMeta","flattenHydratedBlock","hydratedBlock","blk","blkPayloads","flattenHydratedBlocks","hydratedBlocks","flatMap","blk","flattenHydratedBlock","assertEx","isDefined","asBlockBoundWitnessWithStorageMeta","isTransactionBoundWitnessWithStorageMeta","assertEx","PayloadBuilder","isAnyPayload","StepSizes","hexToBigInt","toAddress","span","isTransfer","netBalancesForPayloads","payloads","span","balances","payload","isTransfer","from","address","amount","Object","entries","transfers","toAddress","hexToBigInt","hexToBigInt","span","isTransfer","netTransfersForPayloads","payloads","span","transfers","payload","isTransfer","from","to","amount","Object","entries","hexToBigInt","hexToBigInt","toHex","isObject","isNegativeBigInt","value","isObject","negative","isPositiveBigInt","positive","parseSignedBigInt","hexToBigInt","Error","toSignedBigInt","toHex","toPositiveBigInt","stepSize","calculateFramesFromRange","range","step","size","stepSize","start","Math","trunc","fitted","remaining","push","min","i","StepSizes","deepCalculateFramesFromRange","range","startingStep","StepSizes","length","fitted","remaining","step","newRemaining","newFittedFrames","newRemainingFrames","calculateFramesFromRange","push","i","toSorted","a","b","asHash","toSafeJsonString","asBlockBoundWitnessWithStorageMeta","StepSizes","blockFromBlockNumber","context","blockNumber","head","result","store","chainMap","get","currentBlock","asBlockBoundWitnessWithStorageMeta","required","block","jumpHash","previous","jumpBlockNumber","step","stepSize","StepSizes","entries","possibleJumpBlockNumber","asHash","step_hashes","at","newBlock","toSafeJsonString","Error","hashFromBlockNumber","context","blockNumber","blockFromBlockNumber","_hash","AsObjectFactory","isPayloadOfSchemaType","isStorageMeta","BalancesStepSummarySchema","isBalancesStepSummary","isPayloadOfSchemaType","asBalancesStepSummary","AsObjectFactory","create","isBalancesStepSummaryWithStorageMeta","value","isStorageMeta","asBalancesStepSummaryWithStorageMeta","StepSummarySchema","AsObjectFactory","isPayloadOfSchemaType","isStorageMeta","TransfersStepSummarySchema","isTransfersStepSummary","isPayloadOfSchemaType","asTransfersStepSummary","AsObjectFactory","create","isTransfersStepSummaryWithStorageMeta","value","isStorageMeta","asTransfersStepSummaryWithStorageMeta","balancesStepSummaryFromRange","context","range","frameHeadHash","hashFromBlockNumber","frameSize","head","result","undefined","hash","payloads","hydrateBlock","store","balances","address","balance","Object","entries","netBalancesForPayloads","toSignedBigInt","schema","BalancesStepSummarySchema","stepSize","step","StepSizes","indexOf","assertEx","join","summaryResult","summaryMap","get","isAnyPayload","stepSemaphores","acquire","subRanges","deepCalculateFramesFromRange","promises","map","subRange","subResults","Promise","all","bigIntBalances","subResult","parseSignedBigInt","set","release","finalResult","PayloadBuilder","addStorageMeta","asAddress","spanRootAsync","isDefined","asBlockBoundWitnessWithStorageMeta","balancesSummary","context","spanRootAsync","head","headResult","store","chainMap","get","headBoundWitness","asBlockBoundWitnessWithStorageMeta","required","rangeStart","isDefined","windowSize","Math","max","block","ranges","deepCalculateFramesFromRange","summaries","Promise","all","map","range","balancesStepSummaryFromRange","balances","summary","address","balance","Object","entries","validAddress","asAddress","parseSignedBigInt","isReadArchivist","obj","get","undefined","next","assertEx","PayloadBuilder","isAnyPayload","StepSizes","transfersStepSummaryFromRange","context","range","frameHeadHash","hashFromBlockNumber","frameSize","head","result","undefined","hash","payloads","hydrateBlock","store","transfers","from","toMap","Object","entries","netTransfersForPayloads","to","amount","toSignedBigInt","schema","TransfersStepSummarySchema","stepSize","step","StepSizes","indexOf","assertEx","join","summaryResult","summaryMap","get","isAnyPayload","stepSemaphores","acquire","subRanges","deepCalculateFramesFromRange","promises","map","subRange","subResults","Promise","all","bigIntBalances","subResult","transfer","parseSignedBigInt","set","release","finalResult","PayloadBuilder","addStorageMeta","asAddress","spanRootAsync","isDefined","asBlockBoundWitnessWithStorageMeta","transfersSummary","context","spanRootAsync","head","headResult","store","chainMap","get","headBoundWitness","asBlockBoundWitnessWithStorageMeta","required","rangeStart","isDefined","windowSize","Math","max","block","ranges","deepCalculateFramesFromRange","summaries","Promise","all","map","range","transfersStepSummaryFromRange","transfers","summary","from","toMap","Object","entries","validFrom","asAddress","to","transfer","validTo","parseSignedBigInt","readPayloadMapFromStore","store","isReadArchivist","get","hash","getMany","hashes","has","isDefined","hydrateBlock","chainMap","maxDepth","minDepth","assertEx","bw","asBlockBoundWitnessWithStorageMeta","blkPayloads","payload_hashes","allHashesPresent","transactions","filter","isTransactionBoundWitnessWithStorageMeta","transactionsPayloadHashes","flatMap","tx","transactionsPayloads","allPayloadsHashes","Set","p","_hash","allPayloads","allPayloadsFiltered","filterAs","asTransactionBoundWitnessWithStorageMeta","transactionsFromHydratedBlock","block","filterAs","asTransactionBoundWitnessWithStorageMeta","assertEx","isBlockBoundWitnessWithStorageMeta","isTransactionBoundWitnessWithStorageMeta","tryHydrateBlock","archivist","hash","maxDepth","assertEx","bw","get","find","isBlockBoundWitnessWithStorageMeta","undefined","blkPayloads","payload_hashes","transactions","filter","isTransactionBoundWitnessWithStorageMeta","transactionsPayloadHashes","flatMap","tx","transactionsPayloads","allPayloadsHashes","Set","p","_hash","allPayloads","allPayloadsFiltered","has","z","globalRegistry","z","isLocalhost","hostname","endsWith","getUrl","host","port","scheme","isLocalhost","TODO","z","MnemonicStringZod","string","transform","s","trim","replaceAll","refine","includes","split","length","message","describe","ApiConfigZod","object","host","string","default","register","globalRegistry","description","title","type","mnemonic","MnemonicStringZod","optional","port","coerce","number","globalRegistry","z","AppConfigZod","object","port","coerce","number","default","register","description","title","type","globalRegistry","z","BridgeConfigZod","object","host","string","default","register","globalRegistry","description","title","type","mnemonic","MnemonicStringZod","optional","port","coerce","number","globalRegistry","z","ChainConfigZod","object","id","string","optional","register","description","title","type","globalRegistry","z","EvmInfuraConfigZod","object","projectId","string","optional","register","description","title","type","projectSecret","EvmJsonRpcConfigZod","url","EvmConfigZod","chainId","infura","describe","jsonRpc","LogLevel","globalRegistry","z","LogLevels","Object","keys","LogConfigZod","object","logLevel","enum","default","register","choices","description","title","type","silent","boolean","AddressZod","asAddress","globalRegistry","z","ProducerConfigZod","object","allowlist","preprocess","val","split","map","s","asAddress","trim","array","AddressZod","optional","register","globalRegistry","description","title","type","disableIntentRedeclaration","boolean","healthCheckPort","coerce","number","heartbeatInterval","default","minStake","mnemonic","MnemonicStringZod","port","rewardAddress","string","isDefined","isUndefined","globalRegistry","z","hasMongoConfig","config","isUndefined","isDefined","connectionString","database","domain","password","username","MongoConfigZod","object","string","min","optional","register","globalRegistry","description","title","type","globalRegistry","z","StorageConfigZod","object","mongo","MongoConfigZod","optional","describe","root","string","register","globalRegistry","description","title","type","globalRegistry","z","OpenTelemetryConfigZod","object","otlpEndpoint","url","optional","register","description","title","type","TelemetryConfigZod","otel","describe","Xl1CommonConfigSchema","object","LogConfigZod","shape","describe","ConfigZod","api","ApiConfigZod","default","parse","app","AppConfigZod","bridge","BridgeConfigZod","chain","ChainConfigZod","evm","EvmConfigZod","producer","ProducerConfigZod","storage","StorageConfigZod","telemetry","TelemetryConfigZod","getDefaultConfig","z","DescriptionSchema","string","TitleSchema","JSONSchemaMetaSchema","object","id","optional","title","description","deprecated","boolean","catchall","unknown","GlobalMetaSchema","extend","ChoicesSchema","array","union","number","literal","undefined","readonly","UsageMetaSchema","choices","default","group","hidden","type","isUsageMeta","v","safeParse","success","StakeEventNames","toAddress","XYO_NETWORK_STAKING_ADDRESS","addressStakeWeight","stakeContract","staked","by","startEthBlock","endEthBlock","stakeAddedFilter","filters","StakeAdded","XYO_NETWORK_STAKING_ADDRESS","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","accountStakes","accountStakeCount","getStakeCountForAddress","blockTag","i","stake","getStake","push","ethStakedAddress","toAddress","prefix","toLowerCase","networkStakes","filter","s","totalStake","amount","totalWeight","addIndex","removeIndex","length","blockNumber","args","claimedRewards","_address","toAddress","toAddress","XYO_NETWORK_STAKING_ADDRESS","startingStakes","stakeContract","staked","ethBlock","stakeAddedFilter","filters","StakeAdded","toAddress","XYO_NETWORK_STAKING_ADDRESS","prefix","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","stakes","event","by","args","toLowerCase","amount","filteredStakes","address","Object","entries","stakersAsOfBlock","stakeContract","staked","ethBlock","stakes","startingStakes","results","address","amount","Object","entries","push","toAddress","prefix","toAddress","XYO_NETWORK_STAKING_ADDRESS","totalStakeWeight","stakeContract","staked","startEthBlock","endEthBlock","stakeAddedFilter","filters","StakeAdded","XYO_NETWORK_STAKING_ADDRESS","stakeAddedEvents","queryFilter","stakeRemovedFilter","StakeRemoved","stakeRemovedEvents","stakes","startingStakes","totalWeight","addIndex","removeIndex","i","length","blockNumber","by","toAddress","args","toLowerCase","prefix","amount","Object","values","reduce","a","b","unclaimedRewards","_address","Error","assertEx","asTimePayload","TimeSchema","xl1BlockNumberToEthBlockNumber","context","xl1BlockNumber","blockHash","hashFromBlockNumber","hydratedBlock","hydrateBlock","store","timePayload","asTimePayload","find","p","schema","TimeSchema","required","assertEx","ethereum","assertEx","toHex","BoundWitnessBuilder","PayloadBuilder","defaultTransactionFees","buildTransaction","chain","onChainPayloads","offChainPayloads","signer","nbf","exp","from","fees","defaultTransactionFees","undefined","Array","isArray","Error","txBoundWitnessFields","base","toHex","gasLimit","gasPrice","priority","elevatedHashes","PayloadBuilder","hashes","script","elevatedHash","push","fields","assertEx","at","address","length","tx","txPayloads","BoundWitnessBuilder","meta","$signatures","payloads","signers","build","addStorageMeta","toHex","BoundWitnessBuilder","PayloadBuilder","defaultTransactionFees","buildUnsignedTransaction","chain","onChainPayloads","offChainPayloads","nbf","exp","from","fees","defaultTransactionFees","txBoundWitnessFields","base","toHex","gasLimit","gasPrice","priority","elevatedHashes","PayloadBuilder","hashes","script","elevatedHash","push","fields","length","tx","txPayloads","BoundWitnessBuilder","meta","$signatures","payloads","build","addStorageMeta","delay","isDefined","PayloadBuilder","DEFAULT_CONFIRMATION_ATTEMPTS","DEFAULT_DELAY_BETWEEN_ATTEMPTS","confirmSubmittedTransaction","viewer","transaction","options","attempts","maxAttempts","delay","attemptDelay","txBWHash","PayloadBuilder","hash","logger","log","tx","transactionByHash","undefined","isDefined","error","Error","assertEx","hydrateTypedBoundWitness","tryHydrateTypedBoundWitness","isAllowedBlockPayload","isSignedTransactionBoundWitnessWithStorageMeta","tryHydrateTransaction","chainMap","hash","tryHydrateTypedBoundWitness","get","hashes","getMany","next","Error","isSignedTransactionBoundWitnessWithStorageMeta","hydrateTransaction","hydrateTypedBoundWitness","flattenHydratedTransaction","hydratedTransaction","tx","txPayloads","flattenHydratedTransactions","hydratedTransactions","flatMap","tryHydrateElevatedTransaction","undefined","transaction","payloads","opCodes","script","filter","operation","startsWith","elevatedPayloads","opCode","code","split","elevatedPayload","find","payload","_hash","isAllowedBlockPayload","push","length","hydrateElevatedTransaction","context","assertEx","PayloadBuilder","transactionBlockByteCount","transaction","payloads","cleanTransaction","PayloadBuilder","omitStorageMeta","transactionBytes","JSON","stringify","length","cleanPayloads","reduce","acc","payload","asHash","crackOperation","operation","parts","split","length","Error","slice","crackOperations","operations","map","op","transactionElevatedPayloadHashes","transaction","elevateOperations","crackOperations","script","filter","op","map","asHash","transactionElevatedPayloads","payloads","hashes","elevatedPayloads","payload","includes","_hash","AttoXL1","TransactionGasCosts","transactionBytesRequiredGas","transaction","payloads","transactionBlockBytes","transactionBlockByteCount","AttoXL1","TransactionGasCosts","characterStorage","BigInt","transactionRequiredGas","hydratedTransaction","elevatedPayloads","transactionElevatedPayloads","hashes","length","signatures","addresses","hashValidation","signatureValidation","payloadValidation","filterAs","assertEx","asHash","isAllowedBlockPayloadWithHashStorageMeta","tryExtractElevatedHashesFromScript","strings","hashes","filter","str","startsWith","map","split","filterAs","h","asHash","extractElevatedHashesFromScript","filtered","assertEx","length","tryExtractElevatedHashes","tx","bw","payloads","script","p","includes","_hash","isAllowedBlockPayloadWithHashStorageMeta","extractElevatedHashes","toArrayBuffer","assertEx","hexFromArrayBuffer","PayloadBuilder","signTransaction","tx","account","assertEx","from","address","signedTx","structuredClone","addresses","previous_hashes","previousHash","hash","PayloadBuilder","dataHash","hashBytes","toArrayBuffer","signature","sign","$signatures","hexFromArrayBuffer","HDWallet","WALLET_COMPLIANCE","COIN_TYPES","Ethereum","ACCOUNT_TYPE","GANACHE","XYO","CHANGE_ADDRESS","META_MASK","ADDRESS_INDEX","DEFAULT_WALLET_PATH","generateXyoBaseWalletFromPhrase","walletPhrase","wallet","HDWallet","fromPhrase","DEFAULT_WALLET_PATH"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"$schema": "http://json.schemastore.org/package.json",
|
|
3
3
|
"name": "@xyo-network/xl1-protocol-sdk",
|
|
4
|
-
"version": "1.15.
|
|
4
|
+
"version": "1.15.5",
|
|
5
5
|
"description": "XYO Layer One SDK Protocol",
|
|
6
6
|
"homepage": "https://xylabs.com",
|
|
7
7
|
"bugs": {
|
|
@@ -55,7 +55,8 @@
|
|
|
55
55
|
"@xyo-network/typechain": "~4.0.10",
|
|
56
56
|
"@xyo-network/wallet": "~5.1.6",
|
|
57
57
|
"@xyo-network/wallet-model": "~5.1.6",
|
|
58
|
-
"@xyo-network/xl1-protocol": "~1.12.
|
|
58
|
+
"@xyo-network/xl1-protocol": "~1.12.69",
|
|
59
|
+
"async-mutex": "~0.5.0",
|
|
59
60
|
"zod": "~4.1.12"
|
|
60
61
|
},
|
|
61
62
|
"devDependencies": {
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
/* eslint-disable max-statements */
|
|
1
2
|
import { assertEx } from '@xylabs/assert'
|
|
2
3
|
import { type Address } from '@xylabs/hex'
|
|
3
4
|
import { PayloadBuilder } from '@xyo-network/payload-builder'
|
|
@@ -47,31 +48,36 @@ export async function balancesStepSummaryFromRange(
|
|
|
47
48
|
result = summaryResult as WithStorageMeta<BalancesStepSummary>
|
|
48
49
|
} else {
|
|
49
50
|
// We do not have it, so lets build it
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
subRange
|
|
54
|
-
|
|
55
|
-
|
|
51
|
+
await context.stepSemaphores[step].acquire()
|
|
52
|
+
try {
|
|
53
|
+
const subRanges = deepCalculateFramesFromRange(range, step - 1)
|
|
54
|
+
const promises = subRanges.map(subRange => balancesStepSummaryFromRange(
|
|
55
|
+
context,
|
|
56
|
+
subRange,
|
|
57
|
+
))
|
|
58
|
+
const subResults = await Promise.all(promises)
|
|
56
59
|
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
60
|
+
// add them all up
|
|
61
|
+
const bigIntBalances: Record<Address, bigint> = {}
|
|
62
|
+
for (const subResult of subResults) {
|
|
63
|
+
for (const [address, balance] of Object.entries(subResult.balances)) {
|
|
64
|
+
bigIntBalances[address as Address] = (bigIntBalances[address as Address] ?? 0n) + parseSignedBigInt(balance)
|
|
65
|
+
}
|
|
62
66
|
}
|
|
63
|
-
}
|
|
64
67
|
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
68
|
+
const balances: Record<Address, SignedBigInt> = {}
|
|
69
|
+
for (const [address, balance] of Object.entries(bigIntBalances)) {
|
|
70
|
+
balances[address as Address] = toSignedBigInt(balance)
|
|
71
|
+
}
|
|
69
72
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
+
result = {
|
|
74
|
+
schema: BalancesStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, balances,
|
|
75
|
+
}
|
|
73
76
|
|
|
74
|
-
|
|
77
|
+
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)
|
|
78
|
+
} finally {
|
|
79
|
+
context.stepSemaphores[step].release()
|
|
80
|
+
}
|
|
75
81
|
}
|
|
76
82
|
}
|
|
77
83
|
// console.log(`balanceStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { ReadArchivist } from '@xyo-network/archivist-model'
|
|
2
2
|
import type { Payload } from '@xyo-network/payload-model'
|
|
3
|
+
import type { Semaphore } from 'async-mutex'
|
|
3
4
|
|
|
4
5
|
import type { MapTypeRead, MapTypeWrite } from '../../map/index.ts'
|
|
5
6
|
import type { ChainContextRead } from '../../model/index.ts'
|
|
@@ -10,6 +11,7 @@ export function isReadArchivist(obj: unknown): obj is ReadArchivist {
|
|
|
10
11
|
}
|
|
11
12
|
|
|
12
13
|
export interface ChainSummaryContextRead<T extends Payload> extends ChainContextRead {
|
|
14
|
+
stepSemaphores: Semaphore[]
|
|
13
15
|
summaryMap: MapTypeRead<string, T>
|
|
14
16
|
windowSize?: number
|
|
15
17
|
}
|
|
@@ -49,38 +49,43 @@ export async function transfersStepSummaryFromRange(
|
|
|
49
49
|
if (isAnyPayload(summaryResult)) {
|
|
50
50
|
result = summaryResult as WithStorageMeta<TransfersStepSummary>
|
|
51
51
|
} else {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
subRange
|
|
57
|
-
|
|
58
|
-
|
|
52
|
+
await context.stepSemaphores[step].acquire()
|
|
53
|
+
// We do not have it, so lets build it
|
|
54
|
+
try {
|
|
55
|
+
const subRanges = deepCalculateFramesFromRange(range, step - 1)
|
|
56
|
+
const promises = subRanges.map(subRange => transfersStepSummaryFromRange(
|
|
57
|
+
context,
|
|
58
|
+
subRange,
|
|
59
|
+
))
|
|
60
|
+
const subResults = await Promise.all(promises)
|
|
59
61
|
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
62
|
+
// add them all up
|
|
63
|
+
const bigIntBalances: Record<Address, Record<Address, bigint>> = {}
|
|
64
|
+
for (const subResult of subResults) {
|
|
65
|
+
for (const [from, toMap] of Object.entries(subResult.transfers)) {
|
|
66
|
+
bigIntBalances[from as Address] = bigIntBalances[from as Address] ?? {}
|
|
67
|
+
for (const [to, transfer] of Object.entries(toMap)) {
|
|
68
|
+
bigIntBalances[from as Address][to as Address] = (bigIntBalances[from as Address][to as Address] ?? 0n) + parseSignedBigInt(transfer)
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const transfers: Record<Address, Record<Address, SignedBigInt>> = {}
|
|
74
|
+
for (const [from, toMap] of Object.entries(bigIntBalances)) {
|
|
75
|
+
transfers[from as Address] = transfers[from as Address] ?? {}
|
|
65
76
|
for (const [to, transfer] of Object.entries(toMap)) {
|
|
66
|
-
|
|
77
|
+
transfers[from as Address][to as Address] = toSignedBigInt(transfer)
|
|
67
78
|
}
|
|
68
79
|
}
|
|
69
|
-
}
|
|
70
80
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
transfers[from as Address] = transfers[from as Address] ?? {}
|
|
74
|
-
for (const [to, transfer] of Object.entries(toMap)) {
|
|
75
|
-
transfers[from as Address][to as Address] = toSignedBigInt(transfer)
|
|
81
|
+
result = {
|
|
82
|
+
schema: TransfersStepSummarySchema, hash: frameHeadHash, stepSize: frameSize, transfers,
|
|
76
83
|
}
|
|
77
|
-
}
|
|
78
84
|
|
|
79
|
-
|
|
80
|
-
|
|
85
|
+
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)
|
|
86
|
+
} finally {
|
|
87
|
+
context.stepSemaphores[step].release()
|
|
81
88
|
}
|
|
82
|
-
|
|
83
|
-
await context.summaryMap.set(`${frameHeadHash}|${frameSize}`, result)
|
|
84
89
|
}
|
|
85
90
|
}
|
|
86
91
|
// console.log(`transfersStepSummaryFromRange-result: head=${head}, range=${range[0]}-${range[1]}: ${toSafeJsonString(result, 10)}`)
|