@xyo-network/xl1-protocol 1.3.35 → 1.3.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/dist/index.d.ts +503 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/neutral/index.mjs +10 -10
  4. package/dist/neutral/index.mjs.map +1 -1
  5. package/dist/node/index.mjs +10 -10
  6. package/dist/node/index.mjs.map +1 -1
  7. package/dist/types/block/AllowedBlockPayload.d.ts +2 -2
  8. package/dist/types/block/AllowedBlockPayload.d.ts.map +1 -1
  9. package/dist/types/chain/ChainAnalyzer.d.ts +1 -1
  10. package/dist/types/chain/ChainAnalyzer.d.ts.map +1 -1
  11. package/dist/types/index.d.ts +12 -12
  12. package/dist/types/index.d.ts.map +1 -1
  13. package/dist/types/iterator/ChainIterator.d.ts +3 -3
  14. package/dist/types/iterator/ChainIterator.d.ts.map +1 -1
  15. package/dist/types/iterator/ChainIteratorEventData.d.ts +1 -1
  16. package/dist/types/iterator/ChainIteratorEventData.d.ts.map +1 -1
  17. package/dist/types/payload/elevatable/ChainStakeIntent.d.ts +1 -1
  18. package/dist/types/payload/elevatable/ChainStakeIntent.d.ts.map +1 -1
  19. package/dist/types/provider/v1/XyoNetwork.d.ts +1 -1
  20. package/dist/types/provider/v1/XyoNetwork.d.ts.map +1 -1
  21. package/dist/types/provider/v1/XyoProvider.d.ts +2 -2
  22. package/dist/types/provider/v1/XyoProvider.d.ts.map +1 -1
  23. package/dist/types/provider/v1/XyoRunner.d.ts +1 -1
  24. package/dist/types/provider/v1/XyoRunner.d.ts.map +1 -1
  25. package/dist/types/provider/v1/XyoSigner.d.ts +2 -2
  26. package/dist/types/provider/v1/XyoSigner.d.ts.map +1 -1
  27. package/dist/types/provider/v1/XyoViewer.d.ts +3 -3
  28. package/dist/types/provider/v1/XyoViewer.d.ts.map +1 -1
  29. package/dist/types/provider/v2/viewer/Account.d.ts +1 -1
  30. package/dist/types/provider/v2/viewer/Account.d.ts.map +1 -1
  31. package/dist/types/provider/v2/viewer/Block.d.ts +1 -1
  32. package/dist/types/provider/v2/viewer/Block.d.ts.map +1 -1
  33. package/dist/types/provider/v2/viewer/Chain.d.ts +1 -1
  34. package/dist/types/provider/v2/viewer/Chain.d.ts.map +1 -1
  35. package/dist/types/provider/v2/viewer/Transaction.d.ts +1 -1
  36. package/dist/types/provider/v2/viewer/Transaction.d.ts.map +1 -1
  37. package/dist/types/repository/TransactionReadRepository.d.ts +1 -1
  38. package/dist/types/repository/TransactionReadRepository.d.ts.map +1 -1
  39. package/dist/types/repository/TransactionRepositoryIterator.d.ts +1 -1
  40. package/dist/types/repository/TransactionRepositoryIterator.d.ts.map +1 -1
  41. package/dist/types/repository/TransactionWriteRepository.d.ts +1 -1
  42. package/dist/types/repository/TransactionWriteRepository.d.ts.map +1 -1
  43. package/dist/types/services/BlockProducer.d.ts +3 -3
  44. package/dist/types/services/BlockProducer.d.ts.map +1 -1
  45. package/dist/types/services/Election.d.ts +1 -1
  46. package/dist/types/services/Election.d.ts.map +1 -1
  47. package/dist/types/services/PendingTransactionsService.d.ts +1 -1
  48. package/dist/types/services/PendingTransactionsService.d.ts.map +1 -1
  49. package/dist/types/services/stakeIntent/StakeIntentService.d.ts +1 -1
  50. package/dist/types/services/stakeIntent/StakeIntentService.d.ts.map +1 -1
  51. package/dist/types/transaction/TransactionBoundWitness.d.ts +2 -2
  52. package/dist/types/transaction/TransactionBoundWitness.d.ts.map +1 -1
  53. package/dist/types/validation/block/BlockValidationFunction.d.ts +1 -1
  54. package/dist/types/validation/block/BlockValidationFunction.d.ts.map +1 -1
  55. package/dist/types/validation/block/HydratedBlockStateValidationFunction.d.ts +1 -1
  56. package/dist/types/validation/block/HydratedBlockStateValidationFunction.d.ts.map +1 -1
  57. package/dist/types/validation/block/HydratedBlockValidationFunction.d.ts +1 -1
  58. package/dist/types/validation/block/HydratedBlockValidationFunction.d.ts.map +1 -1
  59. package/dist/types/validation/payload/InBlockPayloadValidationFunction.d.ts +1 -1
  60. package/dist/types/validation/payload/InBlockPayloadValidationFunction.d.ts.map +1 -1
  61. package/dist/types/validation/transaction/HydratedTransactionStateValidationFunction.d.ts +1 -1
  62. package/dist/types/validation/transaction/HydratedTransactionStateValidationFunction.d.ts.map +1 -1
  63. package/dist/types/validation/transaction/HydratedTransactionValidationFunction.d.ts +1 -1
  64. package/dist/types/validation/transaction/HydratedTransactionValidationFunction.d.ts.map +1 -1
  65. package/package.json +11 -3
  66. package/src/block/AllowedBlockPayload.ts +3 -3
  67. package/src/chain/ChainAnalyzer.ts +1 -1
  68. package/src/index.ts +12 -12
  69. package/src/iterator/ChainIterator.ts +4 -3
  70. package/src/iterator/ChainIteratorEventData.ts +1 -1
  71. package/src/payload/elevatable/ChainStakeIntent.ts +2 -1
  72. package/src/provider/v1/XyoNetwork.ts +1 -1
  73. package/src/provider/v1/XyoProvider.ts +3 -2
  74. package/src/provider/v1/XyoRunner.ts +1 -1
  75. package/src/provider/v1/XyoSigner.ts +2 -2
  76. package/src/provider/v1/XyoViewer.ts +3 -3
  77. package/src/provider/v2/viewer/Account.ts +1 -1
  78. package/src/provider/v2/viewer/Block.ts +2 -1
  79. package/src/provider/v2/viewer/Chain.ts +2 -1
  80. package/src/provider/v2/viewer/Transaction.ts +2 -1
  81. package/src/repository/TransactionReadRepository.ts +2 -1
  82. package/src/repository/TransactionRepositoryIterator.ts +2 -1
  83. package/src/repository/TransactionWriteRepository.ts +2 -1
  84. package/src/services/BlockProducer.ts +3 -3
  85. package/src/services/Election.ts +2 -1
  86. package/src/services/PendingTransactionsService.ts +2 -1
  87. package/src/services/stakeIntent/StakeIntentService.ts +1 -1
  88. package/src/transaction/TransactionBoundWitness.ts +3 -2
  89. package/src/validation/block/BlockValidationFunction.ts +1 -1
  90. package/src/validation/block/HydratedBlockStateValidationFunction.ts +1 -1
  91. package/src/validation/block/HydratedBlockValidationFunction.ts +1 -1
  92. package/src/validation/payload/InBlockPayloadValidationFunction.ts +1 -1
  93. package/src/validation/transaction/HydratedTransactionStateValidationFunction.ts +1 -1
  94. package/src/validation/transaction/HydratedTransactionValidationFunction.ts +1 -1
  95. package/tsconfig.json +21 -0
@@ -0,0 +1,503 @@
1
+ import * as _xylabs_promise from '@xylabs/promise';
2
+ import { Promisable } from '@xylabs/promise';
3
+ import { MeterProvider, TracerProvider, Meter, Tracer } from '@opentelemetry/api';
4
+ import { Payload, WithSources, WithStorageMeta, WithHashStorageMeta, Schema } from '@xyo-network/payload-model';
5
+ import { SchemaPayload } from '@xyo-network/schema-payload-plugin';
6
+ import * as _xylabs_object from '@xylabs/object';
7
+ import { EmptyObject, JsonValue } from '@xylabs/object';
8
+ import { Address, Hex, Hash } from '@xylabs/hex';
9
+ import { BoundWitness, Signed } from '@xyo-network/boundwitness-model';
10
+ import { BaseParams } from '@xylabs/base';
11
+ import { EventData, BaseEmitter } from '@xylabs/events';
12
+ import { ArchivistInstance, WriteArchivist, ReadArchivist, HydratedBoundWitnessWithStorageMeta } from '@xyo-network/archivist-model';
13
+ import { AccountInstance } from '@xyo-network/account-model';
14
+ import { Logger } from '@xylabs/logger';
15
+ import { WalletInstance } from '@xyo-network/wallet-model';
16
+
17
+ type Initializable<T, R> = (params: T) => Promisable<R>;
18
+
19
+ interface OpenTelemetryProviders {
20
+ meterProvider?: MeterProvider;
21
+ traceProvider?: TracerProvider;
22
+ }
23
+
24
+ type XL1 = bigint & {
25
+ readonly _tag: 'XL1';
26
+ };
27
+ declare const XL1: (value: bigint) => XL1;
28
+ type MicroXL1 = bigint & {
29
+ readonly _tag: 'MicroXL1';
30
+ };
31
+ declare const MicroXL1: (value: bigint) => MicroXL1;
32
+ declare const mXL1ToXL1: (value: MicroXL1) => XL1;
33
+ declare const mXL1FromXL1: (value: XL1) => MicroXL1;
34
+
35
+ interface Addressable {
36
+ address: Address;
37
+ }
38
+
39
+ interface BlockStart {
40
+ nbf: number;
41
+ }
42
+ interface BlockEnd {
43
+ exp: number;
44
+ }
45
+ interface OptionalBlockDuration extends Partial<BlockStart>, Partial<BlockEnd> {
46
+ }
47
+ interface BlockDuration extends BlockStart, BlockEnd {
48
+ }
49
+
50
+ declare const BlockNumberSchema: "network.xyo.chain.block.number";
51
+ type BlockNumberSchema = typeof BlockNumberSchema;
52
+ interface BlockNumberFields {
53
+ block: Hex;
54
+ chain?: Hex;
55
+ }
56
+ type BlockNumber = Payload<BlockNumberFields, BlockNumberSchema>;
57
+ declare const isBlockNumber: (x?: unknown | null) => x is BlockNumber;
58
+ declare const asBlockNumber: {
59
+ <TType extends BlockNumber>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
60
+ <TType extends BlockNumber>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<BlockNumber>, config?: _xylabs_object.TypeCheckConfig): TType;
61
+ };
62
+ declare const asOptionalBlockNumber: <TType extends BlockNumber>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
63
+ declare const isBlockNumberWithSources: (x?: unknown | null) => x is WithSources<BlockNumber>;
64
+ declare const asBlockNumberWithSources: {
65
+ <TType extends WithSources<BlockNumber>>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
66
+ <TType extends WithSources<BlockNumber>>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<WithSources<BlockNumber>>, config?: _xylabs_object.TypeCheckConfig): TType;
67
+ };
68
+ declare const asOptionalBlockNumberWithSources: <TType extends WithSources<BlockNumber>>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
69
+
70
+ interface ChainReference {
71
+ chain: Address;
72
+ }
73
+
74
+ interface FromFields {
75
+ from: Address;
76
+ }
77
+ declare const hasFrom: (value: unknown) => value is FromFields;
78
+ interface ExecutableFields {
79
+ script: string[];
80
+ }
81
+ type Executable<T extends EmptyObject = EmptyObject> = T & ExecutableFields;
82
+ type OptionalExecutable<T extends EmptyObject = EmptyObject> = T & Partial<ExecutableFields>;
83
+ declare const isExecutable: <T extends EmptyObject>(value: T | undefined) => value is Executable<T>;
84
+ declare const asExecutable: <T extends EmptyObject>(value: T | undefined) => Executable<T> | undefined;
85
+
86
+ declare const ChainStakeIntentSchema: "network.xyo.chain.stake.intent";
87
+ type ChainStakeIntentSchema = typeof ChainStakeIntentSchema;
88
+ type Intent = 'producer';
89
+ interface ChainStakeIntentFields extends BlockDuration, FromFields {
90
+ intent: Intent;
91
+ }
92
+ type ChainStakeIntent = Payload<ChainStakeIntentFields, ChainStakeIntentSchema>;
93
+ declare const isChainStakeIntent: (x?: unknown | null) => x is ChainStakeIntent;
94
+ declare const asChainStakeIntent: {
95
+ <TType extends ChainStakeIntent>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
96
+ <TType extends ChainStakeIntent>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<ChainStakeIntent>, config?: _xylabs_object.TypeCheckConfig): TType;
97
+ };
98
+ declare const asOptionalChainStakeIntent: <TType extends ChainStakeIntent>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
99
+
100
+ declare const HashSchema: "network.xyo.hash";
101
+ type HashSchema = typeof HashSchema;
102
+ interface HashFields {
103
+ hash: Hash;
104
+ }
105
+ type HashPayload = Payload<HashFields, HashSchema>;
106
+ declare const isHashPayload: (x?: unknown | null) => x is HashPayload;
107
+ declare const asHashPayload: {
108
+ <TType extends HashPayload>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
109
+ <TType extends HashPayload>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<HashPayload>, config?: _xylabs_object.TypeCheckConfig): TType;
110
+ };
111
+ declare const asHashPayloadWithStorageMeta: {
112
+ <TType extends HashPayload>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
113
+ <TType extends HashPayload>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<HashPayload>, config?: _xylabs_object.TypeCheckConfig): TType;
114
+ };
115
+ declare const asOptionalHashPayload: <TType extends HashPayload>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
116
+
117
+ declare const TransferSchema: "network.xyo.transfer";
118
+ type TransferSchema = typeof TransferSchema;
119
+ interface TransferFields extends FromFields {
120
+ epoch: number;
121
+ transfers: Record<Address, Hex>;
122
+ }
123
+ type Transfer = Payload<TransferFields, TransferSchema>;
124
+ declare const isTransfer: (x?: unknown | null) => x is Transfer;
125
+ declare const asTransfer: {
126
+ <TType extends Transfer>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
127
+ <TType extends Transfer>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<Transfer>, config?: _xylabs_object.TypeCheckConfig): TType;
128
+ };
129
+ declare const asOptionalTransfer: <TType extends Transfer>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
130
+
131
+ interface TransactionFeesBigInt {
132
+ base: MicroXL1;
133
+ gasLimit: MicroXL1;
134
+ gasPrice: MicroXL1;
135
+ priority: MicroXL1;
136
+ }
137
+ type TransactionFeesHex = {
138
+ [K in keyof TransactionFeesBigInt]: Hex;
139
+ };
140
+ interface TransactionFeesFields {
141
+ fees: TransactionFeesHex;
142
+ }
143
+ declare const minTransactionFees: TransactionFeesBigInt;
144
+ declare const defaultTransactionFees: TransactionFeesBigInt;
145
+
146
+ interface TransactionBoundWitnessFields extends BlockDuration, TransactionFeesFields {
147
+ chain: Address;
148
+ }
149
+ type TransactionBoundWitness = BoundWitness<TransactionBoundWitnessFields & OptionalExecutable & FromFields>;
150
+ declare const isTransactionBoundWitness: (value: unknown) => value is TransactionBoundWitness;
151
+ declare const isSignedTransactionBoundWitness: (value: unknown) => value is Signed<TransactionBoundWitness>;
152
+ declare const isSigned: <T extends BoundWitness = BoundWitness>(value: unknown) => value is Signed<T>;
153
+ declare const isTransactionBoundWitnessWithStorageMeta: (value: unknown) => value is WithStorageMeta<TransactionBoundWitness>;
154
+ declare const isSignedTransactionBoundWitnessWithStorageMeta: (value: unknown) => value is WithStorageMeta<Signed<TransactionBoundWitness>>;
155
+ declare const asTransactionBoundWitness: {
156
+ <TType extends TransactionBoundWitness>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
157
+ <TType extends TransactionBoundWitness>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<TransactionBoundWitness>, config?: _xylabs_object.TypeCheckConfig): TType;
158
+ };
159
+ declare const asOptionalTransactionBoundWitness: <TType extends TransactionBoundWitness>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
160
+ declare const asTransactionBoundWitnessWithStorageMeta: {
161
+ <TType extends WithStorageMeta<TransactionBoundWitness>>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
162
+ <TType extends WithStorageMeta<TransactionBoundWitness>>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<WithStorageMeta<TransactionBoundWitness>>, config?: _xylabs_object.TypeCheckConfig): TType;
163
+ };
164
+ declare const asOptionalTransactionBoundWitnessWithStorageMeta: <TType extends WithStorageMeta<TransactionBoundWitness>>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
165
+
166
+ type HydratedTransaction<T extends TransactionBoundWitness = TransactionBoundWitness, P extends Payload = Payload> = [T, P[]];
167
+ type HydratedTransactionWithStorageMeta<T extends HydratedTransaction = HydratedTransaction> = [WithStorageMeta<T[0]>, WithStorageMeta<T[1][number]>[]];
168
+ type HydratedTransactionWithHashStorageMeta<T extends HydratedTransaction = HydratedTransaction> = [WithHashStorageMeta<T[0]>, WithHashStorageMeta<T[1][number]>[]];
169
+ type SignedHydratedTransaction<T extends HydratedTransaction = HydratedTransaction> = [Signed<T[0]>, T[1][number][]] & HydratedTransaction;
170
+ type SignedHydratedTransactionWithStorageMeta<T extends HydratedTransaction = HydratedTransaction> = [WithStorageMeta<Signed<T[0]>>, WithStorageMeta<T[1][number]>[]] & SignedHydratedTransaction<T> & HydratedTransaction;
171
+
172
+ type AllowedBlockPayload = Transfer | ChainStakeIntent | SchemaPayload | TransactionBoundWitness | HashPayload;
173
+ declare const AllowedBlockPayloadSchemas: Schema[];
174
+ type AllowedBlockPayloadSchema = typeof AllowedBlockPayloadSchemas[number];
175
+ declare const isAllowedBlockPayloadSchema: (value: unknown) => value is AllowedBlockPayloadSchema;
176
+ declare const isAllowedBlockPayload: (value: unknown) => value is AllowedBlockPayload;
177
+ declare const isAllowedBlockPayloadWithHashStorageMeta: (value: unknown) => value is WithStorageMeta<AllowedBlockPayload>;
178
+
179
+ interface BlockBoundWitnessMeta {
180
+ $epoch: number;
181
+ }
182
+ interface BlockBoundWitnessFields {
183
+ block: number;
184
+ chain: Hex;
185
+ previous: Hash | null;
186
+ protocol: number;
187
+ step_hashes: Hex[];
188
+ }
189
+ type BlockBoundWitness = BoundWitness<BlockBoundWitnessFields & BlockBoundWitnessMeta>;
190
+ declare const isBlockBoundWitness: (value: unknown) => value is BlockBoundWitness;
191
+ declare const isBlockBoundWitnessWithStorageMeta: (value: unknown) => value is WithStorageMeta<BlockBoundWitness>;
192
+ declare const asBlockBoundWitness: {
193
+ <TType extends BlockBoundWitness>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
194
+ <TType extends BlockBoundWitness>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<BlockBoundWitness>, config?: _xylabs_object.TypeCheckConfig): TType;
195
+ };
196
+ declare const asOptionalBlockBoundWitness: <TType extends BlockBoundWitness>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
197
+ declare const asBlockBoundWitnessWithStorageMeta: {
198
+ <TType extends WithStorageMeta<BlockBoundWitness>>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
199
+ <TType extends WithStorageMeta<BlockBoundWitness>>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<WithStorageMeta<BlockBoundWitness>>, config?: _xylabs_object.TypeCheckConfig): TType;
200
+ };
201
+ declare const asOptionalBlockBoundWitnessWithStorageMeta: <TType extends WithStorageMeta<BlockBoundWitness>>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
202
+
203
+ type HydratedBlock = [WithStorageMeta<BlockBoundWitness>, WithStorageMeta<Payload>[]];
204
+ type SignedHydratedBlock = [WithStorageMeta<Signed<BlockBoundWitness>>, WithStorageMeta<Payload>[]] & HydratedBlock;
205
+
206
+ interface ChainAnalyzer<T extends Payload = Payload> {
207
+ onBlock(block: HydratedBlock): Promisable<boolean>;
208
+ result(): T;
209
+ shouldContinue(): boolean;
210
+ }
211
+
212
+ declare const StepSizes: readonly [10, 105, 1103, 11576, 121551, 1276282, 13400956];
213
+
214
+ declare const TransactionGasCosts: {
215
+ readonly characterStorage: MicroXL1;
216
+ readonly payloadValidation: MicroXL1;
217
+ readonly signatureValidation: MicroXL1;
218
+ readonly hashValidation: MicroXL1;
219
+ readonly balanceValidation: MicroXL1;
220
+ };
221
+
222
+ interface ReadRepository<TId, TData> {
223
+ get(id: TId): Promise<TData | undefined>;
224
+ }
225
+ interface IterableRepository<TId, TData> {
226
+ next(id: TId): Promise<TData | undefined>;
227
+ }
228
+ interface WriteRepository<TData, TResp> {
229
+ insert(data: TData): Promise<TResp>;
230
+ }
231
+
232
+ interface TransactionReadRepository extends ReadRepository<TransactionBoundWitness, HydratedTransaction> {
233
+ }
234
+
235
+ interface TransactionRepositoryIterator extends IterableRepository<TransactionBoundWitness, HydratedTransaction> {
236
+ }
237
+
238
+ interface TransactionWriteRepository extends WriteRepository<HydratedTransaction, boolean> {
239
+ }
240
+
241
+ interface TransactionRepository extends TransactionReadRepository, TransactionWriteRepository {
242
+ }
243
+ interface ReadonlyIterableTransactionRepository extends TransactionReadRepository, TransactionRepositoryIterator {
244
+ }
245
+ interface IterableTransactionRepository extends TransactionRepository, TransactionRepositoryIterator {
246
+ }
247
+
248
+ interface AccountBalanceService {
249
+ getBalanceValue?: (address: Address) => bigint;
250
+ getBalanceValues?: Record<Address, bigint>;
251
+ getBalance(address: Address): Hex;
252
+ getBalances(): Record<Address, Hex>;
253
+ sync(head: Hash): Promise<void>;
254
+ }
255
+
256
+ type NextBlockProducer = IterableRepository<BlockBoundWitness, HydratedBlock>;
257
+ interface BlockProducer extends Addressable, NextBlockProducer {
258
+ }
259
+
260
+ type ServiceName = Exclude<string, 'reserved-service-name-value'>;
261
+ interface Service {
262
+ logger?: Logger;
263
+ meter?: Meter;
264
+ tracer?: Tracer;
265
+ }
266
+
267
+ interface BlockRewardService extends Service {
268
+ getRewardForBlock(block: bigint): Promisable<bigint>;
269
+ }
270
+
271
+ interface ChainContractViewer {
272
+ active(): Promise<bigint>;
273
+ chainId(): Promise<Address>;
274
+ forkedAtBlockNumber(): Promise<bigint>;
275
+ forkedAtHash(): Promise<bigint>;
276
+ forkedChainId(): Promise<Address>;
277
+ minWithdrawalBlocks(): Promise<bigint>;
278
+ rewardsContract(): Promise<string>;
279
+ stakingTokenAddress(): Promise<string>;
280
+ }
281
+
282
+ declare const ChainIdentificationPayloadSchema: "network.xyo.chain.identification";
283
+ type ChainIdentificationPayloadSchema = typeof ChainIdentificationPayloadSchema;
284
+ interface ChainIdentification {
285
+ id: Address;
286
+ }
287
+ type ChainIdentificationPayload = Payload<ChainIdentification, ChainIdentificationPayloadSchema>;
288
+ declare const isChainIdentificationPayload: (x?: unknown | null) => x is ChainIdentificationPayload;
289
+
290
+ declare const ChainInformationPayloadSchema: "network.xyo.chain.information";
291
+ type ChainInformationPayloadSchema = typeof ChainInformationPayloadSchema;
292
+
293
+ interface ChainInformation extends ChainIdentification {
294
+ }
295
+ type ChainInformationPayload = Payload<ChainIdentification, ChainInformationPayloadSchema>;
296
+ declare const isChainInformationPayload: (x?: unknown | null) => x is ChainInformationPayload;
297
+
298
+ interface ChainStaker {
299
+ addStake(staked: string, amount: bigint): Promise<boolean>;
300
+ removeStake(slot: bigint): Promise<boolean>;
301
+ withdrawStake(slot: bigint): Promise<boolean>;
302
+ }
303
+
304
+ interface ChainStakeViewer extends ChainContractViewer {
305
+ activeByAddressStaked(address: string): Promise<bigint>;
306
+ activeByStaker(address: string): Promise<bigint>;
307
+ pending(): Promise<bigint>;
308
+ pendingByStaker(staker: string): Promise<bigint>;
309
+ withdrawn(): Promise<bigint>;
310
+ withdrawnByStaker(staker: string): Promise<bigint>;
311
+ }
312
+
313
+ interface ChainService extends ChainInformation, ChainContractViewer, ChainStakeViewer, ChainStaker, Service {
314
+ }
315
+
316
+ interface ElectionService extends Service {
317
+ getCreatorCommitteeForNextBlock(current: BlockBoundWitness): Promise<Address[]>;
318
+ }
319
+
320
+ interface ChainIndexingServiceStateFields<T extends JsonValue = JsonValue> {
321
+ endBlockHash: Hash;
322
+ startBlockHash?: Hash;
323
+ state: T;
324
+ }
325
+ declare const ChainIndexingServiceStateSchema: "network.xyo.chain.indexing.service.state";
326
+ type ChainIndexingServiceStateSchema = typeof ChainIndexingServiceStateSchema;
327
+ type ChainIndexingServiceState<T extends JsonValue = JsonValue> = Payload<ChainIndexingServiceStateFields<T>, ChainIndexingServiceStateSchema>;
328
+ declare const isChainIndexingServiceState: <T extends JsonValue = JsonValue>(payload?: unknown) => payload is ChainIndexingServiceState<T>;
329
+ declare const asChainIndexingServiceState: {
330
+ <TType extends ChainIndexingServiceState<JsonValue>>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
331
+ <TType extends ChainIndexingServiceState<JsonValue>>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<ChainIndexingServiceState<JsonValue>>, config?: _xylabs_object.TypeCheckConfig): TType;
332
+ };
333
+ declare const isChainIndexingServiceStateWithStorageMeta: <T extends JsonValue = JsonValue>(value: unknown) => value is WithStorageMeta<ChainIndexingServiceState<T>>;
334
+ declare const asChainIndexingServiceStateWithStorageMeta: {
335
+ <TType extends WithStorageMeta<ChainIndexingServiceState<JsonValue>>>(value: _xylabs_promise.AnyNonPromise, config?: _xylabs_object.TypeCheckConfig): TType | undefined;
336
+ <TType extends WithStorageMeta<ChainIndexingServiceState<JsonValue>>>(value: _xylabs_promise.AnyNonPromise, assert: _xylabs_object.StringOrAlertFunction<WithStorageMeta<ChainIndexingServiceState<JsonValue>>>, config?: _xylabs_object.TypeCheckConfig): TType;
337
+ };
338
+ declare const asOptionalChainIndexingServiceStateWithStorageMeta: <TType extends WithStorageMeta<ChainIndexingServiceState<JsonValue>>>(value: _xylabs_promise.AnyNonPromise) => TType | undefined;
339
+
340
+ interface StakeIntentService {
341
+ getDeclaredCandidateRanges(address: Address, intent: Intent): Promise<Readonly<Readonly<[number, number]>[]>>;
342
+ getDeclaredCandidatesForBlock(block: number, intent: Intent): Promise<Address[]>;
343
+ isStakedForBlock(block: number, intent: Intent, address: Address): Promise<boolean>;
344
+ }
345
+
346
+ interface ChainServiceCollection {
347
+ account: WalletInstance;
348
+ balanceService: AccountBalanceService;
349
+ chainArchivist: ArchivistInstance;
350
+ chainContractViewer: ChainContractViewer;
351
+ chainInformation: ChainInformation;
352
+ chainIterator?: EventingChainBlockNumberIterator;
353
+ chainStakeViewer: ChainStakeViewer;
354
+ chainStaker: ChainStaker;
355
+ chainSubmissionsArchivistWrite: WriteArchivist;
356
+ electionService: ElectionService;
357
+ producer: BlockProducer;
358
+ rewardService: BlockRewardService;
359
+ stakeIntentService: StakeIntentService;
360
+ }
361
+
362
+ type BaseServiceParams<TAdditionalParams extends EmptyObject = EmptyObject> = BaseParams<TAdditionalParams & OpenTelemetryProviders>;
363
+ type BaseAccountableServiceParams = BaseServiceParams<{
364
+ account: AccountInstance;
365
+ }>;
366
+
367
+ interface PendingTransactionsService extends Service {
368
+ getPendingTransactions(head: Hash, limit: number, timeout?: number): Promise<HydratedTransaction[]>;
369
+ }
370
+
371
+ type HeadEventArgs = {
372
+ blocks: [BlockBoundWitness];
373
+ };
374
+ interface HeadEventData extends EventData {
375
+ headUpdated: HeadEventArgs;
376
+ }
377
+ interface ChainIteratorEventData extends HeadEventData {
378
+ }
379
+
380
+ interface ChainIterator<TKey, THead> extends ReadRepository<TKey, BlockBoundWitness>, IterableRepository<TKey, BlockBoundWitness> {
381
+ chainIdentification: ChainIdentification;
382
+ head(): Promise<THead>;
383
+ previous(cursor?: TKey | undefined, limit?: number): Promise<BlockBoundWitness[]>;
384
+ updateHead(head: THead): Promise<void>;
385
+ }
386
+ interface EventingChainIterator<TKey, THead> extends ChainIterator<TKey, THead>, BaseEmitter<BaseParams, ChainIteratorEventData> {
387
+ }
388
+ interface ChainBlockNumberIterator extends ChainIterator<number, BlockBoundWitness> {
389
+ }
390
+ interface EventingChainBlockNumberIterator extends EventingChainIterator<number, BlockBoundWitness> {
391
+ }
392
+ interface ChainHashIterator extends ChainIterator<Hash, Hash> {
393
+ }
394
+ interface EventingChainHashIterator extends EventingChainIterator<Hash, Hash> {
395
+ }
396
+ interface XyoChainIteratorParams extends BaseServiceParams {
397
+ chainArchivist: ArchivistInstance;
398
+ head: BlockBoundWitness;
399
+ }
400
+
401
+ type DefaultNetworkIds = 'mainnet' | 'sequence' | 'local';
402
+ type NetworkId<T extends string | void = void> = T extends void ? DefaultNetworkIds : T | DefaultNetworkIds;
403
+
404
+ declare const NetworkStatusSchema: "network.xyo.chain.status";
405
+ type NetworkStatusSchema = typeof NetworkStatusSchema;
406
+ type NetworkStatusState = 'online' | 'offline' | 'degraded' | 'unknown';
407
+ type NetworkStatusUpdate = {
408
+ end: number;
409
+ start: number;
410
+ update: string;
411
+ };
412
+ interface NetworkStatusFields {
413
+ description: string;
414
+ state: NetworkStatusState;
415
+ updates?: NetworkStatusUpdate[];
416
+ }
417
+ type NetworkStatus = Payload<NetworkStatusFields, NetworkStatusSchema>;
418
+ declare const isNetworkStatus: (x?: unknown | null) => x is NetworkStatus;
419
+
420
+ interface XyoPayloadLakeViewer {
421
+ getPayloads(hashes: Hash[]): Promisable<Payload[]>;
422
+ }
423
+ interface XyoPayloadLakeProvider extends XyoPayloadLakeViewer {
424
+ addPayloads(payloads: Payload[]): Promisable<Hash[]>;
425
+ }
426
+ interface XyoDataLakeViewer extends XyoPayloadLakeViewer {
427
+ fetch(hashes: Hash[], maxDepth?: number): Promisable<(ArrayBuffer | Payload)[]>;
428
+ get(hashes: Hash[]): Promisable<(ArrayBuffer | Payload)[]>;
429
+ trace(hashes: Hash[]): Promisable<[(ArrayBuffer | Payload), Payload[]][]>;
430
+ }
431
+ interface XyoDataLakeProvider extends XyoDataLakeViewer, XyoPayloadLakeProvider {
432
+ add(items: ArrayBuffer[]): Promisable<Hash[]>;
433
+ }
434
+
435
+ interface XyoNetwork {
436
+ status(): Promisable<NetworkStatus>;
437
+ }
438
+
439
+ interface XyoRunner {
440
+ broadcastTransaction(transaction: SignedHydratedTransaction): Promisable<Hash>;
441
+ }
442
+
443
+ interface XyoSigner {
444
+ address(): Promisable<Address>;
445
+ createSignedTransaction(chain: Address, elevatedPayloads: AllowedBlockPayload[], additionalPayloads: Payload[], nbf: number, exp: number, fees: TransactionFeesBigInt, from?: Address): Promisable<Signed<TransactionBoundWitness>>;
446
+ }
447
+
448
+ interface XyoViewer {
449
+ accountBalance: (address: Address) => Promisable<bigint>;
450
+ accountHistory: (address: Address) => Promisable<[TransactionBoundWitness[], Transfer[]]>;
451
+ blockByHash(hash: Hash): Promisable<SignedHydratedBlock | null>;
452
+ blockByNumber(blockNumber: number): Promisable<SignedHydratedBlock | null>;
453
+ blocksByHash(hash: Hash, limit?: number): Promisable<SignedHydratedBlock[]>;
454
+ chainId(): Promisable<Address>;
455
+ currentBlock(): Promisable<SignedHydratedBlock>;
456
+ currentBlockHash(): Promisable<Hash>;
457
+ currentBlockNumber(): Promisable<number>;
458
+ transactionByBlockHashAndIndex(blockHash: Hash, transactionIndex: number): Promisable<SignedHydratedTransaction | null>;
459
+ transactionByBlockNumberAndIndex(blockNumber: number, transactionIndex: number): Promisable<SignedHydratedTransaction | null>;
460
+ transactionByHash(transactionHash: Hash): Promisable<SignedHydratedTransaction | null>;
461
+ }
462
+
463
+ interface XyoWallet {
464
+ accounts(): Promisable<Address[]>;
465
+ addChain(chain: Address, name?: string): Promisable<object>;
466
+ chain(): Promisable<Address>;
467
+ chains(): Promisable<object>;
468
+ permissions(): Promisable<Record<string, object>>;
469
+ requestPermissions(permissions: object): Promisable<object>;
470
+ revokePermissions(permissions: object): Promisable<object>;
471
+ switchChain(chain: Address): Promisable<void>;
472
+ }
473
+
474
+ interface XyoProvider {
475
+ network?: XyoNetwork;
476
+ runner?: XyoRunner;
477
+ send?: (elevatedPayloads: AllowedBlockPayload[], additionalPayloads: Payload[], chain?: Address, nbf?: number, exp?: number, from?: Address, fees?: TransactionFeesBigInt) => Promise<Signed<TransactionBoundWitness>>;
478
+ signer?: XyoSigner;
479
+ storage?: XyoDataLakeProvider;
480
+ viewer?: XyoViewer;
481
+ wallet?: XyoWallet;
482
+ }
483
+
484
+ type BlockValidatorFunction = (block: BlockBoundWitness, chainId?: Address) => Promisable<Error[]>;
485
+
486
+ type HydratedBlockStateValidationFunction = (hydratedBlock: HydratedBlock, chainId: Address, archivist: ReadArchivist) => Promisable<Error[]>;
487
+
488
+ type HydratedBlockValidatorFunction = (hydratedBlock: HydratedBlock, chainId?: Address) => Promisable<Error[]>;
489
+
490
+ type BoundWitnessValidationFunction<T extends BoundWitness = BoundWitness> = (bw: T) => Promisable<Error[]>;
491
+
492
+ type HydratedBoundWitnessWithHashStorageMeta<T extends BoundWitness = BoundWitness, P extends Payload = Payload> = [WithHashStorageMeta<T>, WithHashStorageMeta<P>[]];
493
+ type HydratedBoundWitnessValidationFunction<T extends BoundWitness = BoundWitness> = (bw: HydratedBoundWitnessWithHashStorageMeta<T>) => Promisable<Error[]>;
494
+
495
+ type InBlockPayloadValidationFunction = (payload: WithHashStorageMeta<Payload>, block: HydratedBlock) => Promisable<Error[]>;
496
+
497
+ type HydratedTransactionStateValidationFunction<T extends TransactionBoundWitness = TransactionBoundWitness> = (hydratedTransaction: HydratedBoundWitnessWithStorageMeta<T>, chainId: Address, archivist: ReadArchivist) => Promisable<Error[]>;
498
+
499
+ type HydratedTransactionValidatorFunction<T extends TransactionBoundWitness = TransactionBoundWitness> = (hydratedTransaction: HydratedTransactionWithHashStorageMeta<HydratedTransaction<T>>, chainId?: Address) => Promisable<Error[]>;
500
+
501
+ export { AllowedBlockPayloadSchemas, BlockNumberSchema, ChainIdentificationPayloadSchema, ChainIndexingServiceStateSchema, ChainInformationPayloadSchema, ChainStakeIntentSchema, HashSchema, MicroXL1, NetworkStatusSchema, StepSizes, TransactionGasCosts, TransferSchema, XL1, asBlockBoundWitness, asBlockBoundWitnessWithStorageMeta, asBlockNumber, asBlockNumberWithSources, asChainIndexingServiceState, asChainIndexingServiceStateWithStorageMeta, asChainStakeIntent, asExecutable, asHashPayload, asHashPayloadWithStorageMeta, asOptionalBlockBoundWitness, asOptionalBlockBoundWitnessWithStorageMeta, asOptionalBlockNumber, asOptionalBlockNumberWithSources, asOptionalChainIndexingServiceStateWithStorageMeta, asOptionalChainStakeIntent, asOptionalHashPayload, asOptionalTransactionBoundWitness, asOptionalTransactionBoundWitnessWithStorageMeta, asOptionalTransfer, asTransactionBoundWitness, asTransactionBoundWitnessWithStorageMeta, asTransfer, defaultTransactionFees, hasFrom, isAllowedBlockPayload, isAllowedBlockPayloadSchema, isAllowedBlockPayloadWithHashStorageMeta, isBlockBoundWitness, isBlockBoundWitnessWithStorageMeta, isBlockNumber, isBlockNumberWithSources, isChainIdentificationPayload, isChainIndexingServiceState, isChainIndexingServiceStateWithStorageMeta, isChainInformationPayload, isChainStakeIntent, isExecutable, isHashPayload, isNetworkStatus, isSigned, isSignedTransactionBoundWitness, isSignedTransactionBoundWitnessWithStorageMeta, isTransactionBoundWitness, isTransactionBoundWitnessWithStorageMeta, isTransfer, mXL1FromXL1, mXL1ToXL1, minTransactionFees };
502
+ export type { AccountBalanceService, Addressable, AllowedBlockPayload, AllowedBlockPayloadSchema, BaseAccountableServiceParams, BaseServiceParams, BlockBoundWitness, BlockBoundWitnessFields, BlockBoundWitnessMeta, BlockDuration, BlockEnd, BlockNumber, BlockNumberFields, BlockProducer, BlockRewardService, BlockStart, BlockValidatorFunction, BoundWitnessValidationFunction, ChainAnalyzer, ChainBlockNumberIterator, ChainContractViewer, ChainHashIterator, ChainIdentification, ChainIdentificationPayload, ChainIndexingServiceState, ChainIndexingServiceStateFields, ChainInformation, ChainInformationPayload, ChainIterator, ChainIteratorEventData, ChainReference, ChainService, ChainServiceCollection, ChainStakeIntent, ChainStakeIntentFields, ChainStakeViewer, ChainStaker, DefaultNetworkIds, ElectionService, EventingChainBlockNumberIterator, EventingChainHashIterator, EventingChainIterator, Executable, ExecutableFields, FromFields, HashFields, HashPayload, HeadEventArgs, HeadEventData, HydratedBlock, HydratedBlockStateValidationFunction, HydratedBlockValidatorFunction, HydratedBoundWitnessValidationFunction, HydratedBoundWitnessWithHashStorageMeta, HydratedTransaction, HydratedTransactionStateValidationFunction, HydratedTransactionValidatorFunction, HydratedTransactionWithHashStorageMeta, HydratedTransactionWithStorageMeta, InBlockPayloadValidationFunction, Initializable, Intent, IterableRepository, IterableTransactionRepository, NetworkId, NetworkStatus, NetworkStatusFields, NetworkStatusState, NetworkStatusUpdate, NextBlockProducer, OpenTelemetryProviders, OptionalBlockDuration, OptionalExecutable, PendingTransactionsService, ReadRepository, ReadonlyIterableTransactionRepository, Service, ServiceName, SignedHydratedBlock, SignedHydratedTransaction, SignedHydratedTransactionWithStorageMeta, StakeIntentService, TransactionBoundWitness, TransactionBoundWitnessFields, TransactionFeesBigInt, TransactionFeesFields, TransactionFeesHex, TransactionReadRepository, TransactionRepository, TransactionRepositoryIterator, TransactionWriteRepository, Transfer, TransferFields, WriteRepository, XyoChainIteratorParams, XyoDataLakeProvider, XyoDataLakeViewer, XyoNetwork, XyoPayloadLakeProvider, XyoPayloadLakeViewer, XyoProvider, XyoRunner, XyoSigner, XyoViewer, XyoWallet };
503
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sources":["../src/Initializable.ts","../src/OpenTelemetryProviders.ts","../src/XL1.ts","../src/fields/Addressable.ts","../src/fields/BlockDuration.ts","../src/fields/BlockNumber.ts","../src/fields/ChainReference.ts","../src/payload/elevatable/Executable.ts","../src/payload/elevatable/ChainStakeIntent.ts","../src/payload/elevatable/Hash.ts","../src/payload/elevatable/TransferPayload.ts","../src/transaction/TransactionFeesFields.ts","../src/transaction/TransactionBoundWitness.ts","../src/transaction/HydratedTransaction.ts","../src/block/AllowedBlockPayload.ts","../src/block/BlockBoundWitness.ts","../src/block/HydratedBlock.ts","../src/chain/ChainAnalyzer.ts","../src/constants/StepSizes.ts","../src/constants/TransactionGasCosts.ts","../src/repository/Repository.ts","../src/repository/TransactionReadRepository.ts","../src/repository/TransactionRepositoryIterator.ts","../src/repository/TransactionWriteRepository.ts","../src/repository/TransactionRepository.ts","../src/services/AccountBalanceService.ts","../src/services/BlockProducer.ts","../src/services/Service.ts","../src/services/BlockReward.ts","../src/services/Chain/ChainContractViewer.ts","../src/services/Chain/ChainIdentification.ts","../src/services/Chain/ChainInformation.ts","../src/services/Chain/ChainStaker.ts","../src/services/Chain/ChainStakeViewer.ts","../src/services/Chain/ChainService.ts","../src/services/Election.ts","../src/services/stakeIntent/ChainIndexingServiceStateSchema.ts","../src/services/stakeIntent/StakeIntentService.ts","../src/services/ChainServiceCollection.ts","../src/services/Params.ts","../src/services/PendingTransactionsService.ts","../src/iterator/ChainIteratorEventData.ts","../src/iterator/ChainIterator.ts","../src/network/NetworkId.ts","../src/network/Status.ts","../src/provider/v1/XyoDataLake.ts","../src/provider/v1/XyoNetwork.ts","../src/provider/v1/XyoRunner.ts","../src/provider/v1/XyoSigner.ts","../src/provider/v1/XyoViewer.ts","../src/provider/v1/XyoWallet.ts","../src/provider/v1/XyoProvider.ts","../src/validation/block/BlockValidationFunction.ts","../src/validation/block/HydratedBlockStateValidationFunction.ts","../src/validation/block/HydratedBlockValidationFunction.ts","../src/validation/boundwitness/BoundWitnessValidationFunction.ts","../src/validation/boundwitness/HydratedBoundWitnessValidationFunction.ts","../src/validation/payload/InBlockPayloadValidationFunction.ts","../src/validation/transaction/HydratedTransactionStateValidationFunction.ts","../src/validation/transaction/HydratedTransactionValidationFunction.ts"],"sourcesContent":["import type { Promisable } from '@xylabs/promise'\n\nexport type Initializable<T, R> = (params: T) => Promisable<R>\n","import type { MeterProvider, TracerProvider } from '@opentelemetry/api'\n\nexport interface OpenTelemetryProviders {\n meterProvider?: MeterProvider\n traceProvider?: TracerProvider\n}\n","export type XL1 = bigint & { readonly _tag: 'XL1' } // 1e-18\nexport type MicroXL1 = bigint & { readonly _tag: 'MicroXL1' } // 1e-12\n\nexport const XL1 = (value: bigint): XL1 => value as XL1\nexport const MicroXL1 = (value: bigint): MicroXL1 => value as MicroXL1\n\nexport const mXL1ToXL1 = (value: MicroXL1): XL1 => {\n return XL1(BigInt(value) / BigInt(1_000_000))\n}\n\nexport const mXL1FromXL1 = (value: XL1): MicroXL1 => {\n return MicroXL1(BigInt(value) * BigInt(1_000_000))\n}\n","import type { Address } from '@xylabs/hex'\n\n// NOTE: Minimal interface in case of reuse across validators, producers, wallets, modules, etc.\nexport interface Addressable {\n address: Address\n}\n","export interface BlockStart {\n /**\n * The block at which the duration starts\n */\n nbf: number\n}\n\nexport interface BlockEnd {\n /**\n * The block at which the duration ends\n */\n exp: number\n}\n\n/**\n * A optional duration referenced to block numbers\n */\nexport interface OptionalBlockDuration extends Partial<BlockStart>, Partial<BlockEnd> {}\n\n/**\n * A duration referenced to block numbers\n */\nexport interface BlockDuration extends BlockStart, BlockEnd {}\n","import type { Hex } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Payload, WithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nexport const BlockNumberSchema = 'network.xyo.chain.block.number' as const\nexport type BlockNumberSchema = typeof BlockNumberSchema\n\nexport interface BlockNumberFields {\n /**\n * The block number\n */\n block: Hex\n /**\n * The chain id\n */\n chain?: Hex\n}\n/**\n * The number of a block\n */\nexport type BlockNumber = Payload<BlockNumberFields, BlockNumberSchema>\n\n/**\n * Identity function for determining if an object is a BlockNumber\n */\nexport const isBlockNumber = isPayloadOfSchemaType<BlockNumber>(BlockNumberSchema)\nexport const asBlockNumber = AsObjectFactory.create<BlockNumber>(isBlockNumber)\nexport const asOptionalBlockNumber = AsObjectFactory.createOptional<BlockNumber>(isBlockNumber)\n\n/**\n * Identity function for determining if an object is a BlockNumber with sources\n */\nexport const isBlockNumberWithSources = isPayloadOfSchemaTypeWithSources<BlockNumber>(BlockNumberSchema)\nexport const asBlockNumberWithSources = AsObjectFactory.create<WithSources<BlockNumber>>(isBlockNumberWithSources)\nexport const asOptionalBlockNumberWithSources = AsObjectFactory.createOptional<WithSources<BlockNumber>>(isBlockNumberWithSources)\n","import type { Address } from '@xylabs/hex'\n\n/**\n * Required info for a chain reference\n */\nexport interface ChainReference {\n /**\n * The contract address referenced by the chain\n */\n chain: Address\n}\n","import type { Address } from '@xylabs/hex'\nimport type { EmptyObject } from '@xylabs/object'\nimport { isAnyPayload } from '@xyo-network/payload-model'\n\nexport interface FromFields {\n // the address that is treated as the source of this action\n from: Address\n}\n\nexport const hasFrom = (value: unknown): value is FromFields => {\n return (value as FromFields).from !== undefined\n}\n\nexport interface ExecutableFields {\n script: string[]\n}\n\nexport type Executable<T extends EmptyObject = EmptyObject> = T & ExecutableFields\nexport type OptionalExecutable<T extends EmptyObject = EmptyObject> = T & Partial<ExecutableFields>\n\nexport const isExecutable = <T extends EmptyObject>(value: T | undefined): value is Executable<T> => {\n return isAnyPayload(value) && Array.isArray((value as unknown as ExecutableFields).script)\n}\n\nexport const asExecutable = <T extends EmptyObject>(value: T | undefined): Executable<T> | undefined => {\n return isExecutable(value)\n ? value as unknown as Executable<T>\n : undefined\n}\n","import { AsObjectFactory } from '@xylabs/object'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nimport type { BlockDuration } from '#fields'\n\nimport type { FromFields } from './Executable.ts'\n\nexport const ChainStakeIntentSchema = 'network.xyo.chain.stake.intent' as const\nexport type ChainStakeIntentSchema = typeof ChainStakeIntentSchema\n\nexport type Intent = 'producer' // | 'bank'\n\nexport interface ChainStakeIntentFields extends BlockDuration, FromFields {\n /*\n * The intent of the staking\n */\n intent: Intent\n}\n\nexport type ChainStakeIntent = Payload<ChainStakeIntentFields, ChainStakeIntentSchema>\n\nexport const isChainStakeIntent = (x?: unknown | null): x is ChainStakeIntent => {\n return isPayloadOfSchemaType<ChainStakeIntent>(ChainStakeIntentSchema)(x)\n && asNonNegativeInteger(x.nbf) !== undefined\n && asNonNegativeInteger(x.exp) !== undefined\n}\nexport const asChainStakeIntent = AsObjectFactory.create(isChainStakeIntent)\nexport const asOptionalChainStakeIntent = AsObjectFactory.createOptional(isChainStakeIntent)\n\nconst asNonNegativeInteger = (num: number) => {\n return (Number.isInteger(num) && num >= 0) ? num : undefined\n}\n","import type { Hash } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nexport const HashSchema = 'network.xyo.hash' as const\nexport type HashSchema = typeof HashSchema\n\nexport interface HashFields {\n hash: Hash\n}\n\nexport type HashPayload = Payload<HashFields, HashSchema>\n\nexport const isHashPayload = isPayloadOfSchemaType<HashPayload>(HashSchema)\n\nexport const asHashPayload = AsObjectFactory.create(isHashPayload)\nexport const asHashPayloadWithStorageMeta = AsObjectFactory.create(isHashPayload)\nexport const asOptionalHashPayload = AsObjectFactory.createOptional(isHashPayload)\n","import type {\n Address,\n Hex,\n} from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nimport type { FromFields } from './Executable.ts'\n\nexport const TransferSchema = 'network.xyo.transfer' as const\nexport type TransferSchema = typeof TransferSchema\n\nexport interface TransferFields extends FromFields {\n epoch: number\n // the amount that is being sent to another address\n transfers: Record<Address, Hex>\n}\n\n// if this payload is included in a boundwitness, it needs to be available for inspection to be included in block\nexport type Transfer = Payload<TransferFields, TransferSchema>\n\nexport const isTransfer = isPayloadOfSchemaType<Transfer>(TransferSchema)\n\nexport const asTransfer = AsObjectFactory.create(isTransfer)\nexport const asOptionalTransfer = AsObjectFactory.createOptional(isTransfer)\n","import type { Hex } from '@xylabs/hex'\n\nimport { MicroXL1 } from '../XL1.ts'\n\nexport interface TransactionFeesBigInt {\n base: MicroXL1\n gasLimit: MicroXL1\n gasPrice: MicroXL1\n priority: MicroXL1\n}\n\nexport type TransactionFeesHex = {\n [K in keyof TransactionFeesBigInt]: Hex;\n}\n\nexport interface TransactionFeesFields {\n fees: TransactionFeesHex\n}\n\nexport const minTransactionFees: TransactionFeesBigInt = {\n base: MicroXL1(1000n), gasPrice: MicroXL1(1n), gasLimit: MicroXL1(1000n), priority: MicroXL1(0n),\n} as const\n\nexport const defaultTransactionFees: TransactionFeesBigInt = {\n base: minTransactionFees.base, gasPrice: MicroXL1(10n), gasLimit: MicroXL1(1_000_000n), priority: MicroXL1(0n),\n} as const\n","import type { Address } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { BoundWitness, Signed } from '@xyo-network/boundwitness-model'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isStorageMeta } from '@xyo-network/payload-model'\n\nimport type { BlockDuration } from '#fields'\nimport type { FromFields, OptionalExecutable } from '#payload'\n\nimport type { TransactionFeesFields } from './TransactionFeesFields.ts'\n\nexport interface TransactionBoundWitnessFields extends BlockDuration, TransactionFeesFields {\n chain: Address\n}\n\nexport type TransactionBoundWitness = BoundWitness<TransactionBoundWitnessFields & OptionalExecutable & FromFields>\n\nexport const isTransactionBoundWitness = (value: unknown): value is TransactionBoundWitness => {\n const typedObj = value as TransactionBoundWitness\n return isBoundWitness(value)\n && typedObj.chain !== undefined\n && typedObj.fees !== undefined\n && typedObj.exp !== undefined\n && typedObj.nbf !== undefined\n}\n\nexport const isSignedTransactionBoundWitness = (value: unknown): value is Signed<TransactionBoundWitness> => {\n return isTransactionBoundWitness(value) && isSigned(value)\n}\n\nexport const isSigned = <T extends BoundWitness = BoundWitness>(value: unknown): value is Signed<T> =>\n isBoundWitness(value)\n && value.$signatures.length === value.addresses.length\n && value.addresses.length > 0\n\nexport const isTransactionBoundWitnessWithStorageMeta = (value: unknown): value is WithStorageMeta<TransactionBoundWitness> =>\n isTransactionBoundWitness(value)\n && isStorageMeta(value)\n\nexport const isSignedTransactionBoundWitnessWithStorageMeta = (value: unknown): value is WithStorageMeta<Signed<TransactionBoundWitness>> =>\n isSignedTransactionBoundWitness(value)\n && isStorageMeta(value)\n\nexport const asTransactionBoundWitness = AsObjectFactory.create(isTransactionBoundWitness)\nexport const asOptionalTransactionBoundWitness = AsObjectFactory.createOptional(isTransactionBoundWitness)\n\nexport const asTransactionBoundWitnessWithStorageMeta = AsObjectFactory.create(isTransactionBoundWitnessWithStorageMeta)\nexport const asOptionalTransactionBoundWitnessWithStorageMeta = AsObjectFactory.createOptional(isTransactionBoundWitnessWithStorageMeta)\n","import type { Signed } from '@xyo-network/boundwitness-model'\nimport type {\n Payload, WithHashStorageMeta, WithStorageMeta,\n} from '@xyo-network/payload-model'\n\nimport type { TransactionBoundWitness } from './TransactionBoundWitness.ts'\n\nexport type HydratedTransaction<T extends TransactionBoundWitness = TransactionBoundWitness, P extends Payload = Payload> = [T, P[]]\n\nexport type HydratedTransactionWithStorageMeta<T extends HydratedTransaction = HydratedTransaction>\n = [WithStorageMeta<T[0]>, WithStorageMeta<T[1][number]>[]]\n\nexport type HydratedTransactionWithHashStorageMeta<T extends HydratedTransaction = HydratedTransaction>\n = [WithHashStorageMeta<T[0]>, WithHashStorageMeta<T[1][number]>[]]\n\nexport type SignedHydratedTransaction<T extends HydratedTransaction = HydratedTransaction> = [Signed<T[0]>, T[1][number][]] & HydratedTransaction\n\nexport type SignedHydratedTransactionWithStorageMeta<T extends HydratedTransaction = HydratedTransaction>\n = [WithStorageMeta<Signed<T[0]>>, WithStorageMeta<T[1][number]>[]] & SignedHydratedTransaction<T> & HydratedTransaction\n","import { BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport type { Schema, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isHashStorageMeta, isSchema } from '@xyo-network/payload-model'\nimport type { SchemaPayload } from '@xyo-network/schema-payload-plugin'\nimport { isSchemaPayload, SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type {\n ChainStakeIntent, HashPayload, Transfer,\n} from '#payload'\nimport {\n ChainStakeIntentSchema, HashSchema, isChainStakeIntent, isHashPayload, isTransfer, TransferSchema,\n} from '#payload'\nimport { isTransactionBoundWitness, type TransactionBoundWitness } from '#transaction'\n\nexport type AllowedBlockPayload = Transfer | ChainStakeIntent | SchemaPayload | TransactionBoundWitness | HashPayload\nexport const AllowedBlockPayloadSchemas: Schema[] = [TransferSchema, ChainStakeIntentSchema, SchemaSchema, BoundWitnessSchema, HashSchema]\nexport type AllowedBlockPayloadSchema = typeof AllowedBlockPayloadSchemas[number]\n\nexport const isAllowedBlockPayloadSchema = (value: unknown): value is AllowedBlockPayloadSchema => {\n return isSchema(value) && AllowedBlockPayloadSchemas.includes(value)\n}\n\nexport const isAllowedBlockPayload = (value: unknown): value is AllowedBlockPayload => {\n return isTransfer(value) || isChainStakeIntent(value) || isSchemaPayload(value) || isTransactionBoundWitness(value) || isHashPayload(value)\n}\n\nexport const isAllowedBlockPayloadWithHashStorageMeta = (value: unknown): value is WithStorageMeta<AllowedBlockPayload> => {\n return isAllowedBlockPayload(value) && isHashStorageMeta(value)\n}\n","import type { Hash, Hex } from '@xylabs/hex'\nimport { isHex } from '@xylabs/hex'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitness } from '@xyo-network/boundwitness-model'\nimport type { WithStorageMeta } from '@xyo-network/payload-model'\nimport { isStorageMeta } from '@xyo-network/payload-model'\n\nexport interface BlockBoundWitnessMeta {\n $epoch: number\n}\n\nexport interface BlockBoundWitnessFields {\n /** Block number */\n block: number\n /** Chain id - this should be \"0\" for the genesis block */\n chain: Hex\n /** Previous block hash if not block 0 */\n previous: Hash | null /* the previous block hash */\n /** Version of the protocol being used major * 1,000,000 + minor * 1,000 + patch */\n protocol: number\n /** Step hashes */\n step_hashes: Hex[]\n}\n\nexport type BlockBoundWitness = BoundWitness<BlockBoundWitnessFields & BlockBoundWitnessMeta>\n\nexport const isBlockBoundWitness = (value: unknown): value is BlockBoundWitness => {\n const typedObj = value as BlockBoundWitness\n return isBoundWitness(value)\n && Number.isInteger(typedObj.block)\n && isHex(typedObj.chain)\n}\n\nexport const isBlockBoundWitnessWithStorageMeta = (value: unknown): value is WithStorageMeta<BlockBoundWitness> => {\n return isBlockBoundWitness(value) && isStorageMeta(value)\n}\n\nexport const asBlockBoundWitness = AsObjectFactory.create(isBlockBoundWitness)\nexport const asOptionalBlockBoundWitness = AsObjectFactory.createOptional(isBlockBoundWitness)\n\nexport const asBlockBoundWitnessWithStorageMeta = AsObjectFactory.create(isBlockBoundWitnessWithStorageMeta)\nexport const asOptionalBlockBoundWitnessWithStorageMeta = AsObjectFactory.createOptional(isBlockBoundWitnessWithStorageMeta)\n","import type { Signed } from '@xyo-network/boundwitness-model'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\n\nimport type { BlockBoundWitness } from './BlockBoundWitness.ts'\n\nexport type HydratedBlock = [WithStorageMeta<BlockBoundWitness>, WithStorageMeta<Payload>[]]\n\nexport type SignedHydratedBlock = [WithStorageMeta<Signed<BlockBoundWitness>>, WithStorageMeta<Payload>[]] & HydratedBlock\n","import type { Promisable } from '@xylabs/promise'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { HydratedBlock } from '#block'\n\nexport interface ChainAnalyzer<T extends Payload = Payload> {\n onBlock(block: HydratedBlock): Promisable<boolean>\n result(): T\n shouldContinue(): boolean\n}\n","export const StepSizes = [10, 105, 1103, 11_576, 121_551, 1_276_282, 13_400_956] as const\n","import { MicroXL1 } from '../XL1.ts'\n\nexport const TransactionGasCosts = {\n /**\n * The cost of storing each character that is added to the chain\n * This includes the transaction JSON and all the elevated payloads' JSON\n */\n characterStorage: MicroXL1(10n),\n\n /** The cost of static validating every payload that will be included in the chain */\n payloadValidation: MicroXL1(1000n),\n\n /** The cost of validating each signature that will be included in the chain */\n signatureValidation: MicroXL1(1000n),\n\n /** The cost of validating each hash that will be included in the chain */\n hashValidation: MicroXL1(100n),\n\n /** The cost of validating a balance state, triggered by a Transfer payload or gas collection */\n balanceValidation: MicroXL1(100n),\n} as const\n\n/** Gas Calculation\n *\n * 1 Million microXL1 (mXL1) = 1 XL1\n *\n * Gas amount is calculated as follows:\n *\n * 1. Each byte in the transaction cost 10 gas\n * 2. Each payload validation in the transaction costs 1000 gas\n * 3. Each signature verification in the transaction costs 1000 gas\n * 4. Each hash validation in the transaction costs 100 gas\n * 5. Each balance validation in the transaction costs 100 gas\n * 6. Processing/Compute/Storage Cost?\n * 7. operation Costs?\n *\n * The total gas cost is calculated by multiplying the gas amount by the gas price.\n *\n * minGasPrice is initially set to 100 mXL1\n * minBase is initially set to 1000 mXL1\n * minPriority is always 0 mXL1, but can be set to increase the priority of the transaction\n *\n */\n","export interface ReadRepository<TId, TData> {\n get(id: TId): Promise<TData | undefined>\n}\n\nexport interface IterableRepository<TId, TData> {\n next(id: TId): Promise<TData | undefined>\n}\n\nexport interface WriteRepository<TData, TResp> {\n insert(data: TData): Promise<TResp>\n}\n","import type { HydratedTransaction, TransactionBoundWitness } from '#transaction'\n\nimport type { ReadRepository } from './Repository.ts'\n\nexport interface TransactionReadRepository extends ReadRepository<TransactionBoundWitness, HydratedTransaction> {}\n","import type { HydratedTransaction, TransactionBoundWitness } from '#transaction'\n\nimport type { IterableRepository } from './Repository.ts'\n\nexport interface TransactionRepositoryIterator extends IterableRepository<TransactionBoundWitness, HydratedTransaction> {}\n","import type { HydratedTransaction } from '#transaction'\n\nimport type { WriteRepository } from './Repository.ts'\n\nexport interface TransactionWriteRepository extends WriteRepository<HydratedTransaction, boolean> {}\n","import type { TransactionReadRepository } from './TransactionReadRepository.ts'\nimport type { TransactionRepositoryIterator } from './TransactionRepositoryIterator.ts'\nimport type { TransactionWriteRepository } from './TransactionWriteRepository.ts'\n\nexport interface TransactionRepository extends TransactionReadRepository, TransactionWriteRepository {}\n\nexport interface ReadonlyIterableTransactionRepository extends TransactionReadRepository, TransactionRepositoryIterator {}\n\nexport interface IterableTransactionRepository extends TransactionRepository, TransactionRepositoryIterator {}\n","import type {\n Address, Hash, Hex,\n} from '@xylabs/hex'\n\nexport interface AccountBalanceService {\n getBalanceValue?: (address: Address) => bigint\n getBalanceValues?: Record<Address, bigint>\n\n getBalance(address: Address): Hex\n getBalances(): Record<Address, Hex>\n sync(head: Hash): Promise<void>\n}\n","import type { BlockBoundWitness, HydratedBlock } from '#block'\nimport type { Addressable } from '#fields'\nimport type { IterableRepository } from '#repository'\n\nexport type NextBlockProducer = IterableRepository<BlockBoundWitness, HydratedBlock>\n\nexport interface BlockProducer extends Addressable, NextBlockProducer {}\n","import type { Meter, Tracer } from '@opentelemetry/api'\nimport type { Logger } from '@xylabs/logger'\n\nexport type ServiceName = Exclude<string, 'reserved-service-name-value'>\n\nexport interface Service {\n logger?: Logger\n meter?: Meter\n tracer?: Tracer\n}\n","import type { Promisable } from '@xylabs/promise'\n\nimport type { Service } from './Service.ts'\n\nexport interface BlockRewardService extends Service {\n getRewardForBlock(block: bigint): Promisable<bigint>\n}\n","import type { Address } from '@xylabs/hex'\n\nexport interface ChainContractViewer {\n active(): Promise<bigint>\n chainId(): Promise<Address>\n forkedAtBlockNumber(): Promise<bigint>\n forkedAtHash(): Promise<bigint>\n forkedChainId(): Promise<Address>\n minWithdrawalBlocks(): Promise<bigint>\n rewardsContract(): Promise<string>\n stakingTokenAddress(): Promise<string>\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nexport const ChainIdentificationPayloadSchema = 'network.xyo.chain.identification' as const\nexport type ChainIdentificationPayloadSchema = typeof ChainIdentificationPayloadSchema\n\n/**\n * Identification required to uniquely identify a chain\n */\nexport interface ChainIdentification {\n /** @field the id of the chain */\n id: Address\n}\n\nexport type ChainIdentificationPayload = Payload<ChainIdentification, ChainIdentificationPayloadSchema>\nexport const isChainIdentificationPayload = isPayloadOfSchemaType<ChainIdentificationPayload>(ChainIdentificationPayloadSchema)\n","import type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nexport const ChainInformationPayloadSchema = 'network.xyo.chain.information' as const\nexport type ChainInformationPayloadSchema = typeof ChainInformationPayloadSchema\n\nimport type { ChainIdentification } from './ChainIdentification.ts'\n\n/**\n * Information required to produce a chain\n */\nexport interface ChainInformation extends ChainIdentification {\n // TODO: Add these fields which are currently promises on the smart contract\n // forkedAtBlockNumber: bigint\n // forkedAtHash: Hash\n // forkedChainId: Address\n}\n\nexport type ChainInformationPayload = Payload<ChainIdentification, ChainInformationPayloadSchema>\nexport const isChainInformationPayload = isPayloadOfSchemaType<ChainInformationPayload>(ChainInformationPayloadSchema)\n","export interface ChainStaker {\n addStake(staked: string, amount: bigint): Promise<boolean>\n removeStake(slot: bigint): Promise<boolean>\n withdrawStake(slot: bigint): Promise<boolean>\n}\n","import type { ChainContractViewer } from './ChainContractViewer.ts'\n\nexport interface ChainStakeViewer extends ChainContractViewer {\n activeByAddressStaked(address: string): Promise<bigint>\n activeByStaker(address: string): Promise<bigint>\n pending(): Promise<bigint>\n pendingByStaker(staker: string): Promise<bigint>\n withdrawn(): Promise<bigint>\n withdrawnByStaker(staker: string): Promise<bigint>\n}\n","import type { Service } from '../Service.ts'\nimport type { ChainContractViewer } from './ChainContractViewer.ts'\nimport type { ChainInformation } from './ChainInformation.ts'\nimport type { ChainStaker } from './ChainStaker.ts'\nimport type { ChainStakeViewer } from './ChainStakeViewer.ts'\n\nexport interface ChainService extends ChainInformation, ChainContractViewer, ChainStakeViewer, ChainStaker, Service {}\n","import type { Address } from '@xylabs/hex'\n\nimport type { BlockBoundWitness } from '#block'\n\nimport type { Service } from './Service.ts'\n\nexport interface ElectionService extends Service {\n\n /**\n * Given the current block, get the leader for the next block\n * @param current The previous block\n */\n getCreatorCommitteeForNextBlock(current: BlockBoundWitness): Promise<Address[]>\n\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { JsonValue } from '@xylabs/object'\nimport { AsObjectFactory } from '@xylabs/object'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType, isStorageMeta } from '@xyo-network/payload-model'\n\nexport interface ChainIndexingServiceStateFields<T extends JsonValue = JsonValue> {\n /**\n * The hash of the last block that this service has indexing\n */\n endBlockHash: Hash\n /**\n * The hash of the block that the service started indexing. If undefined, the service is\n * assumed to have started indexing from the genesis block\n */\n startBlockHash?: Hash\n /**\n * The indexed state for the range\n */\n state: T\n}\nexport const ChainIndexingServiceStateSchema = 'network.xyo.chain.indexing.service.state' as const\nexport type ChainIndexingServiceStateSchema = typeof ChainIndexingServiceStateSchema\n\n/**\n * The result of a ChainIndexingServiceState\n */\nexport type ChainIndexingServiceState<T extends JsonValue = JsonValue> = Payload<ChainIndexingServiceStateFields<T>, ChainIndexingServiceStateSchema>\n\n/**\n * Identity functions for determining if an object is an ChainIndexingServiceState\n */\nexport const isChainIndexingServiceState = <T extends JsonValue = JsonValue>(payload?: unknown): payload is ChainIndexingServiceState<T> => {\n return isPayloadOfSchemaType<ChainIndexingServiceState<T>>(ChainIndexingServiceStateSchema)(payload)\n}\nexport const asChainIndexingServiceState = AsObjectFactory.create<ChainIndexingServiceState<JsonValue>>(isChainIndexingServiceState)\n\nexport const isChainIndexingServiceStateWithStorageMeta\n= <T extends JsonValue = JsonValue>(value: unknown): value is WithStorageMeta<ChainIndexingServiceState<T>> =>\n isChainIndexingServiceState<T>(value) && isStorageMeta(value)\n\nexport const asChainIndexingServiceStateWithStorageMeta\n= AsObjectFactory.create<WithStorageMeta<ChainIndexingServiceState>>(isChainIndexingServiceStateWithStorageMeta)\n\nexport const asOptionalChainIndexingServiceStateWithStorageMeta\n= AsObjectFactory.createOptional<WithStorageMeta<ChainIndexingServiceState>>(isChainIndexingServiceStateWithStorageMeta)\n","import type { Address } from '@xylabs/hex'\n\nimport type { Intent } from '#payload'\n\nexport interface StakeIntentService {\n\n /**\n * Gets the declared ranges for an address based on historical on-chain data\n * @param address The address to get the declared ranges for\n * @param intent The declared intent to filter for\n */\n getDeclaredCandidateRanges(address: Address, intent: Intent): Promise<Readonly<Readonly<[number, number]>[]>>\n\n /**\n * Gets the declared candidates for a block based on historical on-chain data\n * @param block The block number to get the declared candidates for\n * @param intent The declared intent to filter for\n */\n getDeclaredCandidatesForBlock(block: number, intent: Intent): Promise<Address[]>\n\n /**\n * Checks if the address is staked for a block for a given intent\n * @param block The block number to check\n * @param intent The declared intent to filter for\n * @param address The address to check\n */\n isStakedForBlock(block: number, intent: Intent, address: Address): Promise<boolean>\n}\n","import type { ArchivistInstance, WriteArchivist } from '@xyo-network/archivist-model'\nimport type { WalletInstance } from '@xyo-network/wallet-model'\n\nimport type { EventingChainBlockNumberIterator } from '../iterator/index.ts'\nimport type { AccountBalanceService } from './AccountBalanceService.ts'\nimport type { BlockProducer } from './BlockProducer.ts'\nimport type { BlockRewardService } from './BlockReward.ts'\nimport type {\n ChainContractViewer, ChainInformation, ChainStaker, ChainStakeViewer,\n} from './Chain/index.ts'\nimport type { ElectionService } from './Election.ts'\nimport type { StakeIntentService } from './stakeIntent/index.ts'\n\nexport interface ChainServiceCollection {\n\n account: WalletInstance\n /**\n * Services for working with account balances\n */\n balanceService: AccountBalanceService\n /**\n * The archivist which the chain data is stored in\n */\n chainArchivist: ArchivistInstance\n chainContractViewer: ChainContractViewer\n /**\n * Hydrated information about the chain\n */\n chainInformation: ChainInformation\n /**\n * The chain iterator\n */\n chainIterator?: EventingChainBlockNumberIterator\n chainStakeViewer: ChainStakeViewer\n chainStaker: ChainStaker\n chainSubmissionsArchivistWrite: WriteArchivist\n electionService: ElectionService\n producer: BlockProducer\n rewardService: BlockRewardService\n /**\n * Services for working with staked intents\n */\n stakeIntentService: StakeIntentService\n}\n","import type { BaseParams } from '@xylabs/base'\nimport type { EmptyObject } from '@xylabs/object'\nimport type { AccountInstance } from '@xyo-network/account-model'\n\nimport type { OpenTelemetryProviders } from '../OpenTelemetryProviders.ts'\n\nexport type BaseServiceParams<TAdditionalParams extends EmptyObject = EmptyObject> = BaseParams<TAdditionalParams & OpenTelemetryProviders>\n\nexport type BaseAccountableServiceParams = BaseServiceParams<{\n account: AccountInstance\n}>\n","import type { Hash } from '@xylabs/hex'\n\nimport type { HydratedTransaction } from '#transaction'\n\nimport type { Service } from './Service.ts'\n\nexport interface PendingTransactionsService extends Service {\n getPendingTransactions(head: Hash, limit: number, timeout?: number): Promise<HydratedTransaction[]>\n}\n","import type { EventData } from '@xylabs/events'\n\nimport type { BlockBoundWitness } from '#block'\n\nexport type HeadEventArgs = { blocks: [BlockBoundWitness] }\n\nexport interface HeadEventData extends EventData {\n headUpdated: HeadEventArgs\n}\n\nexport interface ChainIteratorEventData extends HeadEventData { }\n","import type { BaseParams } from '@xylabs/base'\nimport type { BaseEmitter } from '@xylabs/events'\nimport type { Hash } from '@xylabs/hex'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\n\nimport type { BlockBoundWitness } from '#block'\nimport type { IterableRepository, ReadRepository } from '#repository'\nimport type { BaseServiceParams, ChainIdentification } from '#services'\n\nimport type { ChainIteratorEventData } from './ChainIteratorEventData.ts'\n\nexport interface ChainIterator<TKey, THead> extends ReadRepository<TKey, BlockBoundWitness>, IterableRepository<TKey, BlockBoundWitness> {\n chainIdentification: ChainIdentification\n head(): Promise<THead>\n previous(cursor?: TKey | undefined, limit?: number): Promise<BlockBoundWitness[]>\n updateHead(head: THead): Promise<void>\n}\n\nexport interface EventingChainIterator<TKey, THead> extends ChainIterator<TKey, THead>, BaseEmitter<BaseParams, ChainIteratorEventData> { }\n\nexport interface ChainBlockNumberIterator extends ChainIterator<number, BlockBoundWitness> { }\nexport interface EventingChainBlockNumberIterator extends EventingChainIterator<number, BlockBoundWitness> { }\n\nexport interface ChainHashIterator extends ChainIterator<Hash, Hash> { }\nexport interface EventingChainHashIterator extends EventingChainIterator<Hash, Hash> { }\n\nexport interface XyoChainIteratorParams extends BaseServiceParams {\n chainArchivist: ArchivistInstance\n head: BlockBoundWitness\n}\n","export type DefaultNetworkIds = 'mainnet' | 'sequence' | 'local'\nexport type NetworkId<T extends string | void = void> = | T extends void ? DefaultNetworkIds : T | DefaultNetworkIds\n","import type { Payload } from '@xyo-network/payload-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\n\nexport const NetworkStatusSchema = 'network.xyo.chain.status' as const\nexport type NetworkStatusSchema = typeof NetworkStatusSchema\n\nexport type NetworkStatusState = 'online' | 'offline' | 'degraded' | 'unknown'\n\nexport type NetworkStatusUpdate = {\n end: number\n start: number\n update: string\n}\n\nexport interface NetworkStatusFields {\n description: string\n state: NetworkStatusState\n updates?: NetworkStatusUpdate[]\n}\n\nexport type NetworkStatus = Payload<NetworkStatusFields, NetworkStatusSchema>\n\nexport const isNetworkStatus = isPayloadOfSchemaType<NetworkStatus>(NetworkStatusSchema)\n","import type { Hash } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\nimport type { Payload } from '@xyo-network/payload-model'\n\nexport interface XyoPayloadLakeViewer {\n getPayloads(hashes: Hash[]): Promisable<Payload[]>\n}\n\nexport interface XyoPayloadLakeProvider extends XyoPayloadLakeViewer {\n addPayloads(payloads: Payload[]): Promisable<Hash[]>\n}\n\nexport interface XyoDataLakeViewer extends XyoPayloadLakeViewer {\n // if resolves to hash payload, keep going until hitting a non-payload or maxDepth, or unable to find\n fetch(hashes: Hash[], maxDepth?: number): Promisable<(ArrayBuffer | Payload)[]>\n // same as fetch but never follows hash payloads\n get(hashes: Hash[]): Promisable<(ArrayBuffer | Payload)[]>\n // same as fetch, except returns each step\n trace(hashes: Hash[]): Promisable<[(ArrayBuffer | Payload), Payload[]][]>\n}\n\nexport interface XyoDataLakeProvider extends XyoDataLakeViewer, XyoPayloadLakeProvider {\n add(items: ArrayBuffer[]): Promisable<Hash[]>\n}\n","import type { Promisable } from '@xylabs/promise'\n\nimport type { NetworkStatus } from '#network'\n\nexport interface XyoNetwork {\n status(): Promisable<NetworkStatus>\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nimport type { SignedHydratedTransaction } from '#transaction'\n\nexport interface XyoRunner {\n broadcastTransaction(transaction: SignedHydratedTransaction): Promisable<Hash>\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\nimport type { Signed } from '@xyo-network/boundwitness-model'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { AllowedBlockPayload } from '#block'\nimport type { TransactionBoundWitness, TransactionFeesBigInt } from '#transaction'\n\nexport interface XyoSigner {\n address(): Promisable<Address>\n createSignedTransaction(\n chain: Address,\n elevatedPayloads: AllowedBlockPayload[],\n additionalPayloads: Payload[],\n nbf: number,\n exp: number,\n fees: TransactionFeesBigInt,\n from?: Address,\n ): Promisable<Signed<TransactionBoundWitness>>\n}\n","import type { Address, Hash } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nimport type { SignedHydratedBlock } from '#block'\nimport type { Transfer } from '#payload'\nimport type { SignedHydratedTransaction, TransactionBoundWitness } from '#transaction'\n\nexport interface XyoViewer {\n accountBalance: (address: Address) => Promisable<bigint>\n accountHistory: (address: Address) => Promisable<[TransactionBoundWitness[], Transfer[]]>\n\n blockByHash(hash: Hash): Promisable<SignedHydratedBlock | null>\n blockByNumber(blockNumber: number): Promisable<SignedHydratedBlock | null>\n blocksByHash(hash: Hash, limit?: number): Promisable<SignedHydratedBlock[]>\n\n chainId(): Promisable<Address>\n\n currentBlock(): Promisable<SignedHydratedBlock>\n currentBlockHash(): Promisable<Hash>\n currentBlockNumber(): Promisable<number>\n\n transactionByBlockHashAndIndex(blockHash: Hash, transactionIndex: number): Promisable<SignedHydratedTransaction | null>\n transactionByBlockNumberAndIndex(blockNumber: number, transactionIndex: number): Promisable<SignedHydratedTransaction | null>\n transactionByHash(transactionHash: Hash): Promisable<SignedHydratedTransaction | null>\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\n// TODO: define the permissions object and return object types\n\nexport interface XyoWallet {\n accounts(): Promisable<Address[]>\n addChain(chain: Address, name?: string): Promisable<object>\n chain(): Promisable<Address>\n chains(): Promisable<object>\n permissions(): Promisable<Record<string, object>>\n requestPermissions(permissions: object): Promisable<object>\n revokePermissions(permissions: object): Promisable<object>\n switchChain(chain: Address): Promisable<void>\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Signed } from '@xyo-network/boundwitness-model'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { AllowedBlockPayload } from '#block'\nimport type { TransactionBoundWitness, TransactionFeesBigInt } from '#transaction'\n\nimport type { XyoDataLakeProvider } from './XyoDataLake.ts'\nimport type { XyoNetwork } from './XyoNetwork.ts'\nimport type { XyoRunner } from './XyoRunner.ts'\nimport type { XyoSigner } from './XyoSigner.ts'\nimport type { XyoViewer } from './XyoViewer.ts'\nimport type { XyoWallet } from './XyoWallet.ts'\n\nexport interface XyoProvider {\n network?: XyoNetwork\n runner?: XyoRunner\n send?: (\n elevatedPayloads: AllowedBlockPayload[],\n additionalPayloads: Payload[],\n chain?: Address,\n nbf?: number,\n exp?: number,\n from?: Address,\n fees?: TransactionFeesBigInt,\n ) => Promise<Signed<TransactionBoundWitness>>\n signer?: XyoSigner\n storage?: XyoDataLakeProvider\n viewer?: XyoViewer\n wallet?: XyoWallet\n}\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nimport type { BlockBoundWitness } from '#block'\n\nexport type BlockValidatorFunction = (\n block: BlockBoundWitness,\n chainId?: Address,\n) => Promisable<Error[]>\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\nimport type { ReadArchivist } from '@xyo-network/archivist-model'\n\nimport type { HydratedBlock } from '#block'\n\n/**\n * A function that validates a hydrated block against chain state.\n * @param hydratedBlock The hydrated block to validate.\n * @param chainId The chain ID to use for validation.\n * @param archivist The archivist to use for validation.\n * @returns An array of errors if the block is invalid, or an empty array if it is valid.\n */\nexport type HydratedBlockStateValidationFunction = (\n hydratedBlock: HydratedBlock,\n chainId: Address,\n archivist: ReadArchivist,\n) => Promisable<Error[]>\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nimport type { HydratedBlock } from '#block'\n\n/**\n * A function that validates a hydrated block.\n * @param hydratedBlock The hydrated block to validate.\n * @param chainId The chain ID to use for validation.\n * @returns An array of errors if the block is invalid, or an empty array if it is valid.\n */\nexport type HydratedBlockValidatorFunction = (\n hydratedBlock: HydratedBlock,\n chainId?: Address,\n) => Promisable<Error[]>\n","import type { Promisable } from '@xylabs/promise'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\n\nexport type BoundWitnessValidationFunction<T extends BoundWitness = BoundWitness> = (\n bw: T\n) => Promisable<Error[]>\n","import type { Promisable } from '@xylabs/promise'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport type { Payload, WithHashStorageMeta } from '@xyo-network/payload-model'\n\nexport type HydratedBoundWitnessWithHashStorageMeta<T extends BoundWitness = BoundWitness, P extends Payload = Payload>\n = [WithHashStorageMeta<T>, WithHashStorageMeta<P>[]]\n\nexport type HydratedBoundWitnessValidationFunction<T extends BoundWitness = BoundWitness> = (\n bw: HydratedBoundWitnessWithHashStorageMeta<T>\n) => Promisable<Error[]>\n","import type { Promisable } from '@xylabs/promise'\nimport type { Payload, WithHashStorageMeta } from '@xyo-network/payload-model'\n\nimport type { HydratedBlock } from '#block'\n\nexport type InBlockPayloadValidationFunction = (\n payload: WithHashStorageMeta<Payload>, block: HydratedBlock\n) => Promisable<Error[]>\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\nimport type { HydratedBoundWitnessWithStorageMeta, ReadArchivist } from '@xyo-network/archivist-model'\n\nimport type { TransactionBoundWitness } from '#transaction'\n\n/**\n * A function that validates a hydrated transaction against chain state.\n * @param hydratedTransaction The hydrated transaction to validate.\n * @param chainId The chain ID to use for validation.\n * @param archivist The archivist to use for validation.\n * @returns An array of errors if the transaction is invalid, or an empty array if it is valid.\n */\nexport type HydratedTransactionStateValidationFunction<T extends TransactionBoundWitness = TransactionBoundWitness> = (\n hydratedTransaction: HydratedBoundWitnessWithStorageMeta<T>,\n chainId: Address,\n archivist: ReadArchivist,\n) => Promisable<Error[]>\n","import type { Address } from '@xylabs/hex'\nimport type { Promisable } from '@xylabs/promise'\n\nimport type {\n HydratedTransaction, HydratedTransactionWithHashStorageMeta, TransactionBoundWitness,\n} from '#transaction'\n\n/**\n * A function that validates a hydrated transaction.\n * @param bw The hydrated transaction to validate.\n * @param chainId The chain ID to use for validation.\n * @returns An array of errors if the transaction is invalid, or an empty array if it is valid.\n */\nexport type HydratedTransactionValidatorFunction<T extends TransactionBoundWitness = TransactionBoundWitness> = (\n hydratedTransaction: HydratedTransactionWithHashStorageMeta<HydratedTransaction<T>>,\n chainId?: Address,\n) => Promisable<Error[]>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACO;;ACAA;AACP;AACA;AACA;;ACJO;AACP;AACA;AAIO;AAHA;AACP;AACA;AAEO;AACA;AACA;;ACRA;AACP;AACA;;ACHO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACO;AACP;;ACPO;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACA;AACP;AACA;AACA;AACO;;ACnBA;AACP;AACA;;ACDO;AACP;AACA;AACO;AACA;AACP;AACA;AACO;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACP;AACA;AACO;AACA;AACA;AACP;AACA;AACA;AACO;;ACbA;AACA;AACA;AACP;AACA;AACO;AACA;AACA;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACO;;ACdA;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACA;AACP;AACA;AACA;AACO;;ACbA;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACA;;ACTA;AACP;AACA;AACO;AACA;AACA;AACA;AACA;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACO;;ACrBA;AACA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACO;;ACtBA;AACA;;ACDA;AACP;AACA;AACA;AACA;;ACPO;;ACCA;AACP;AACA;AACA;AACA;AACA;AACA;;ACPO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;;ACNO;AACP;;ACDO;AACP;;ACDO;AACP;;ACAO;AACP;AACO;AACP;AACO;AACP;;ACPO;AACP;AACA;AACA;AACA;AACA;AACA;;ACJO;AACA;AACP;;ACHO;AACA;AACP;AACA;AACA;AACA;;ACLO;AACP;AACA;;ACHO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRO;AACA;AACA;AACP;AACA;AACO;AACA;;ACPA;AACA;;AAEA;AACP;AACO;AACA;;ACPA;AACP;AACA;AACA;AACA;;ACHO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;ACHO;AACP;;ACHO;AACP;AACA;;ACFO;AACP;AACA;AACA;AACA;AACO;AACA;AACA;AACA;AACA;AACP;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACO;;ACnBA;AACP;AACA;AACA;AACA;;ACGO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBO;AACA;AACP;AACA;;ACJO;AACP;AACA;;ACHO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;;ACDO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACO;AACP;AACO;AACP;AACO;AACP;AACO;AACP;AACO;AACP;AACA;AACA;;AC3BO;AACA;;ACAA;AACA;AACA;AACA;AACP;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACA;;ACZA;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACP;AACA;;ACdO;AACP;AACA;;ACDO;AACP;AACA;;ACCO;AACP;AACA;AACA;;ACJO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBO;;ACCA;;ACDA;;ACDA;;ACCA;AACA;;ACDA;;ACCA;;ACDA;;;"}