forked from ethereum/execution-apis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
schema.graphqls
535 lines (430 loc) · 14.9 KB
/
schema.graphqls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
"""EIP-2718"""
type AccessTuple {
address: Address!
storageKeys: [Bytes32!]!
}
"""Account is an Ethereum account at a particular block."""
type Account {
"""Address is the address owning the account."""
address: Address!
"""Balance is the balance of the account, in wei."""
balance: BigInt!
"""
TransactionCount is the number of transactions sent from this account,
or in the case of a contract, the number of contracts created. Otherwise
known as the nonce.
"""
transactionCount: Long!
"""
Code contains the smart contract code for this account, if the account
is a (non-self-destructed) contract.
"""
code: Bytes!
"""
Storage provides access to the storage of a contract account, indexed
by its 32 byte slot identifier.
"""
storage(slot: Bytes32!): Bytes32!
}
"""Address is a 20 byte Ethereum address, represented as 0x-prefixed hexadecimal."""
scalar Address
"""
BigInt is a large integer. Input is accepted as either a JSON number or as a string.
Strings may be either decimal or 0x-prefixed hexadecimal. Output values are all
0x-prefixed hexadecimal.
"""
scalar BigInt
"""Block is an Ethereum block."""
type Block {
"""
Number is the number of this block, starting at 0 for the genesis block.
"""
number: Long!
"""Hash is the block hash of this block."""
hash: Bytes32!
"""Parent is the parent block of this block."""
parent: Block
"""Nonce is the block nonce, an 8 byte sequence determined by the miner."""
nonce: Bytes!
"""
TransactionsRoot is the keccak256 hash of the root of the trie of transactions in this block.
"""
transactionsRoot: Bytes32!
"""
TransactionCount is the number of transactions in this block. if
transactions are not available for this block, this field will be null.
"""
transactionCount: Int
"""
StateRoot is the keccak256 hash of the state trie after this block was processed.
"""
stateRoot: Bytes32!
"""
ReceiptsRoot is the keccak256 hash of the trie of transaction receipts in this block.
"""
receiptsRoot: Bytes32!
"""Miner is the account that mined this block."""
miner(block: Long): Account!
"""ExtraData is an arbitrary data field supplied by the miner."""
extraData: Bytes!
"""
GasLimit is the maximum amount of gas that was available to transactions in this block.
"""
gasLimit: Long!
"""
GasUsed is the amount of gas that was used executing transactions in this block.
"""
gasUsed: Long!
"""
BaseFeePerGas is the fee per unit of gas burned by the protocol in this block.
"""
baseFeePerGas: BigInt
"""
NextBaseFeePerGas is the fee per unit of gas which needs to be burned in the next block.
"""
nextBaseFeePerGas: BigInt
"""Timestamp is the unix timestamp at which this block was mined."""
timestamp: Long!
"""
LogsBloom is a bloom filter that can be used to check if a block may
contain log entries matching a filter.
"""
logsBloom: Bytes!
"""MixHash is the hash that was used as an input to the PoW process."""
mixHash: Bytes32!
"""Difficulty is a measure of the difficulty of mining this block."""
difficulty: BigInt!
"""
TotalDifficulty is the sum of all difficulty values up to and including
this block.
"""
totalDifficulty: BigInt!
"""
OmmerCount is the number of ommers (AKA uncles) associated with this
block. If ommers are unavailable, this field will be null.
"""
ommerCount: Int
"""
Ommers is a list of ommer (AKA uncle) blocks associated with this block.
If ommers are unavailable, this field will be null. Depending on your
node, the transactions, transactionAt, transactionCount, ommers,
ommerCount and ommerAt fields may not be available on any ommer blocks.
"""
ommers: [Block]
"""
OmmerAt returns the ommer (AKA uncle) at the specified index. If ommers
are unavailable, or the index is out of bounds, this field will be null.
"""
ommerAt(index: Int!): Block
"""
OmmerHash is the keccak256 hash of all the ommers (AKA uncles)
associated with this block.
"""
ommerHash: Bytes32!
"""
Transactions is a list of transactions associated with this block. If
transactions are unavailable for this block, this field will be null.
"""
transactions: [Transaction!]
"""
TransactionAt returns the transaction at the specified index. If
transactions are unavailable for this block, or if the index is out of
bounds, this field will be null.
"""
transactionAt(index: Int!): Transaction
"""Logs returns a filtered set of logs from this block."""
logs(filter: BlockFilterCriteria!): [Log!]!
"""Account fetches an Ethereum account at the current block's state."""
account(address: Address!): Account!
"""Call executes a local call operation at the current block's state."""
call(data: CallData!): CallResult
"""
EstimateGas estimates the amount of gas that will be required for
successful execution of a transaction at the current block's state.
"""
estimateGas(data: CallData!): Long!
"""RawHeader is the RLP encoding of the block's header."""
rawHeader: Bytes!
"""Raw is the RLP encoding of the block."""
raw: Bytes!
}
"""
BlockFilterCriteria encapsulates log filter criteria for a filter applied
to a single block.
"""
input BlockFilterCriteria {
"""
Addresses is list of addresses that are of interest. If this list is
empty, results will not be filtered by address.
"""
addresses: [Address!]
"""
Topics list restricts matches to particular event topics. Each event has a list
of topics. Topics matches a prefix of that list. An empty element array matches any
topic. Non-empty elements represent an alternative that matches any of the
contained topics.
Examples:
- [] or nil matches any topic list
- [[A]] matches topic A in first position
- [[], [B]] matches any topic in first position, B in second position
- [[A], [B]] matches topic A in first position, B in second position
- [[A, B]], [C, D]] matches topic (A OR B) in first position, (C OR D) in second position
"""
topics: [[Bytes32!]!]
}
"""
Bytes is an arbitrary length binary string, represented as 0x-prefixed hexadecimal.
An empty byte string is represented as '0x'. Byte strings must have an even number of hexadecimal nybbles.
"""
scalar Bytes
"""Bytes32 is a 32 byte binary string, represented as 0x-prefixed hexadecimal."""
scalar Bytes32
"""
CallData represents the data associated with a local contract call.
All fields are optional.
"""
input CallData {
"""From is the address making the call."""
from: Address
"""To is the address the call is sent to."""
to: Address
"""Gas is the amount of gas sent with the call."""
gas: Long
"""GasPrice is the price, in wei, offered for each unit of gas."""
gasPrice: BigInt
"""MaxFeePerGas is the maximum fee per gas offered, in wei."""
maxFeePerGas: BigInt
"""MaxPriorityFeePerGas is the maximum miner tip per gas offered, in wei."""
maxPriorityFeePerGas: BigInt
"""Value is the value, in wei, sent along with the call."""
value: BigInt
"""Data is the data sent to the callee."""
data: Bytes
}
"""CallResult is the result of a local call operation."""
type CallResult {
"""Data is the return data of the called contract."""
data: Bytes!
"""GasUsed is the amount of gas used by the call, after any refunds."""
gasUsed: Long!
"""Status is the result of the call - 1 for success or 0 for failure."""
status: Long!
}
"""
FilterCriteria encapsulates log filter criteria for searching log entries.
"""
input FilterCriteria {
"""
FromBlock is the block at which to start searching, inclusive. Defaults
to the latest block if not supplied.
"""
fromBlock: Long
"""
ToBlock is the block at which to stop searching, inclusive. Defaults
to the latest block if not supplied.
"""
toBlock: Long
"""
Addresses is a list of addresses that are of interest. If this list is
empty, results will not be filtered by address.
"""
addresses: [Address!]
"""
Topics list restricts matches to particular event topics. Each event has a list
of topics. Topics matches a prefix of that list. An empty element array matches any
topic. Non-empty elements represent an alternative that matches any of the
contained topics.
Examples:
- [] or nil matches any topic list
- [[A]] matches topic A in first position
- [[], [B]] matches any topic in first position, B in second position
- [[A], [B]] matches topic A in first position, B in second position
- [[A, B]], [C, D]] matches topic (A OR B) in first position, (C OR D) in second position
"""
topics: [[Bytes32!]!]
}
"""Log is an Ethereum event log."""
type Log {
"""Index is the index of this log in the block."""
index: Int!
"""
Account is the account which generated this log - this will always
be a contract account.
"""
account(block: Long): Account!
"""Topics is a list of 0-4 indexed topics for the log."""
topics: [Bytes32!]!
"""Data is unindexed data for this log."""
data: Bytes!
"""Transaction is the transaction that generated this log entry."""
transaction: Transaction!
}
"""Long is a 64 bit unsigned integer."""
scalar Long
type Mutation {
"""SendRawTransaction sends an RLP-encoded transaction to the network."""
sendRawTransaction(data: Bytes!): Bytes32!
}
"""Pending represents the current pending state."""
type Pending {
"""TransactionCount is the number of transactions in the pending state."""
transactionCount: Int!
"""Transactions is a list of transactions in the current pending state."""
transactions: [Transaction!]
"""Account fetches an Ethereum account for the pending state."""
account(address: Address!): Account!
"""Call executes a local call operation for the pending state."""
call(data: CallData!): CallResult
"""
EstimateGas estimates the amount of gas that will be required for
successful execution of a transaction for the pending state.
"""
estimateGas(data: CallData!): Long!
}
type Query {
"""
Block fetches an Ethereum block by number or by hash. If neither is
supplied, the most recent known block is returned.
"""
block(number: Long, hash: Bytes32): Block
"""
Blocks returns all the blocks between two numbers, inclusive. If
to is not supplied, it defaults to the most recent known block.
"""
blocks(from: Long, to: Long): [Block!]!
"""Pending returns the current pending state."""
pending: Pending!
"""Transaction returns a transaction specified by its hash."""
transaction(hash: Bytes32!): Transaction
"""Logs returns log entries matching the provided filter."""
logs(filter: FilterCriteria!): [Log!]!
"""
GasPrice returns the node's estimate of a gas price sufficient to
ensure a transaction is mined in a timely fashion.
"""
gasPrice: BigInt!
"""
MaxPriorityFeePerGas returns the node's estimate of a gas tip sufficient
to ensure a transaction is mined in a timely fashion.
"""
maxPriorityFeePerGas: BigInt!
"""Syncing returns information on the current synchronisation state."""
syncing: SyncState
"""
ChainID returns the current chain ID for transaction replay protection.
"""
chainID: BigInt!
}
"""SyncState contains the current synchronisation state of the client."""
type SyncState {
"""StartingBlock is the block number at which synchronisation started."""
startingBlock: Long!
"""
CurrentBlock is the point at which synchronisation has presently reached.
"""
currentBlock: Long!
"""HighestBlock is the latest known block number."""
highestBlock: Long!
}
"""Transaction is an Ethereum transaction."""
type Transaction {
"""Hash is the hash of this transaction."""
hash: Bytes32!
"""Nonce is the nonce of the account this transaction was generated with."""
nonce: Long!
"""
Index is the index of this transaction in the parent block. This will
be null if the transaction has not yet been mined.
"""
index: Int
"""
From is the account that sent this transaction - this will always be
an externally owned account.
"""
from(block: Long): Account!
"""
To is the account the transaction was sent to. This is null for
contract-creating transactions.
"""
to(block: Long): Account
"""Value is the value, in wei, sent along with this transaction."""
value: BigInt!
"""GasPrice is the price offered to miners for gas, in wei per unit."""
gasPrice: BigInt!
"""
MaxFeePerGas is the maximum fee per gas offered to include a transaction, in wei.
"""
maxFeePerGas: BigInt
"""
MaxPriorityFeePerGas is the maximum miner tip per gas offered to include a transaction, in wei.
"""
maxPriorityFeePerGas: BigInt
"""
EffectiveTip is the actual amount of reward going to miner after considering the max fee cap.
"""
effectiveTip: BigInt
"""Gas is the maximum amount of gas this transaction can consume."""
gas: Long!
"""InputData is the data supplied to the target of the transaction."""
inputData: Bytes!
"""
Block is the block this transaction was mined in. This will be null if
the transaction has not yet been mined.
"""
block: Block
"""
Status is the return status of the transaction. This will be 1 if the
transaction succeeded, or 0 if it failed (due to a revert, or due to
running out of gas). If the transaction has not yet been mined, this
field will be null.
"""
status: Long
"""
GasUsed is the amount of gas that was used processing this transaction.
If the transaction has not yet been mined, this field will be null.
"""
gasUsed: Long
"""
CumulativeGasUsed is the total gas used in the block up to and including
this transaction. If the transaction has not yet been mined, this field
will be null.
"""
cumulativeGasUsed: Long
"""
EffectiveGasPrice is actual value per gas deducted from the sender's
account. Before EIP-1559, this is equal to the transaction's gas price.
After EIP-1559, it is baseFeePerGas + min(maxFeePerGas - baseFeePerGas,
maxPriorityFeePerGas). Legacy transactions and EIP-2930 transactions are
coerced into the EIP-1559 format by setting both maxFeePerGas and
maxPriorityFeePerGas as the transaction's gas price.
"""
effectiveGasPrice: BigInt
"""
CreatedContract is the account that was created by a contract creation
transaction. If the transaction was not a contract creation transaction,
or it has not yet been mined, this field will be null.
"""
createdContract(block: Long): Account
"""
Logs is a list of log entries emitted by this transaction. If the
transaction has not yet been mined, this field will be null.
"""
logs: [Log!]
r: BigInt!
s: BigInt!
v: BigInt!
"""Envelope transaction support"""
type: Int
accessList: [AccessTuple!]
"""
Raw is the canonical encoding of the transaction.
For legacy transactions, it returns the RLP encoding.
For EIP-2718 typed transactions, it returns the type and payload.
"""
raw: Bytes!
"""
RawReceipt is the canonical encoding of the receipt. For post EIP-2718 typed transactions
this is equivalent to TxType || ReceiptEncoding.
"""
rawReceipt: Bytes!
}