diff --git a/packages/parsers/src/openrpc/1.x/MethodConverter.node.ts b/packages/parsers/src/openrpc/1.x/MethodConverter.node.ts index 82b63ae6b0..8f474cea09 100644 --- a/packages/parsers/src/openrpc/1.x/MethodConverter.node.ts +++ b/packages/parsers/src/openrpc/1.x/MethodConverter.node.ts @@ -9,6 +9,8 @@ import { BaseOpenrpcConverterNodeConstructorArgs, } from "../BaseOpenrpcConverter.node"; import { resolveContentDescriptorObject } from "../utils/resolveContentDescriptorObject"; +import { resolveExample } from "../utils/resolveExample"; +import { resolveExamplePairingOrReference } from "../utils/resolveExamplePairing"; export class MethodConverterNode extends BaseOpenrpcConverterNode< MethodObject, @@ -110,12 +112,51 @@ export class MethodConverterNode extends BaseOpenrpcConverterNode< ].filter(isNonNullish) : [], errors: [], - examples: [], + examples: this.method.examples + ?.map( + ( + example + ): FernRegistry.api.latest.ExampleEndpointCall | undefined => { + const resolvedExample = resolveExamplePairingOrReference( + example, + this.context.openrpc + ); + if (!resolvedExample) return undefined; + return { + name: resolvedExample.name ?? "Example", + path: "", + description: undefined, + snippets: undefined, + pathParameters: {}, + queryParameters: {}, + headers: {}, + requestBody: + resolvedExample.params.length > 0 + ? { + type: "json", + value: resolvedExample.params.map((param) => { + const resolvedParam = resolveExample( + param, + this.context.openrpc + ); + if (!resolvedParam) return undefined; + return resolvedParam.value; + }), + } + : undefined, + responseStatusCode: 200, + responseBody: resolvedExample.result + ? { type: "json", value: resolvedExample.result } + : undefined, + }; + } + ) + .filter(isNonNullish), description: this.input.description, operationId: this.input.name, defaultEnvironment: undefined, environments: [], - availability: undefined, + availability: this.method.deprecated ? "Deprecated" : undefined, requestHeaders: [], responseHeaders: [], snippetTemplates: undefined, diff --git a/packages/parsers/src/openrpc/__test__/__snapshots__/ethereum.json b/packages/parsers/src/openrpc/__test__/__snapshots__/ethereum.json new file mode 100644 index 0000000000..d4a9169e55 --- /dev/null +++ b/packages/parsers/src/openrpc/__test__/__snapshots__/ethereum.json @@ -0,0 +1,3951 @@ +{ + "id": "test-uuid-replacement", + "types": { + "ProofNode": { + "name": "ProofNode", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + }, + "description": "An individual node used to prove a path down a merkle-patricia-tree" + }, + "StorageProofKey": { + "name": "StorageProofKey", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The key used to get the storage slot in its account tree." + }, + "StorageProof": { + "name": "storageProofSet", + "shape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "key", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "StorageProofKey" + } + } + }, + { + "key": "value", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The value of the storage slot in its account tree" + }, + { + "key": "proof", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "ProofNodes" + } + } + } + ] + } + } + }, + "description": "Current block header PoW hash." + }, + "ProofNodes": { + "name": "proofNodes", + "shape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "ProofNode" + } + } + } + }, + "description": "The set of node values needed to traverse a patricia merkle tree (from root to leaf) to retrieve a value" + }, + "PowHash": { + "name": "PowHash", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "Current block header PoW hash." + }, + "SeedHash": { + "name": "SeedHash", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "The seed hash used for the DAG." + }, + "MixHash": { + "name": "MixHash", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "The mix digest." + }, + "Difficulty": { + "name": "Difficulty", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "The boundary condition ('target'), 2^256 / difficulty." + }, + "FilterId": { + "name": "filterId", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "An identifier used to reference the filter." + }, + "BlockHash": { + "name": "blockHash", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The hex representation of the Keccak 256 of the RLP encoded block" + }, + "BlockNumber": { + "name": "BlockNumber", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The hex representation of the block's height" + }, + "BlockNumberTag": { + "name": "blockNumberTag", + "shape": { + "type": "enum", + "values": [ + { + "value": "earliest" + }, + { + "value": "latest" + }, + { + "value": "pending" + } + ] + }, + "description": "The optional block height description" + }, + "BlockOrNull": { + "name": "blockOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Block" + } + } + }, + "IntegerOrNull": { + "name": "integerOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + }, + "AddressOrNull": { + "name": "addressOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + }, + "Receipt": { + "name": "receipt", + "shape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "contractAddress", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "AddressOrNull" + } + }, + "description": "The contract address created, if the transaction was a contract creation, otherwise null" + }, + { + "key": "cumulativeGasUsed", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The gas units used by the transaction" + }, + { + "key": "from", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "From" + } + } + }, + { + "key": "gasUsed", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The total gas used by the transaction" + }, + { + "key": "logs", + "valueShape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Log" + } + } + } + }, + "description": "An array of all the logs triggered during the transaction" + }, + { + "key": "logsBloom", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BloomFilter" + } + } + }, + { + "key": "to", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "To" + } + } + }, + { + "key": "transactionHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + }, + { + "key": "transactionIndex", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionIndex" + } + } + }, + { + "key": "postTransactionState", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + } + } + }, + "description": "The intermediate stateRoot directly after transaction execution." + }, + { + "key": "status", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + } + } + }, + "description": "Whether or not the transaction threw an error." + } + ] + }, + "description": "The receipt of a transaction" + }, + "BloomFilter": { + "name": "bloomFilter", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "A 2048 bit bloom filter from the logs of the transaction. Each log sets 3 bits though taking the low-order 11 bits of each of the first three pairs of bytes in a Keccak 256 hash of the log's byte series" + }, + "Log": { + "name": "log", + "shape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "Sender of the transaction" + }, + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "data", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + }, + "description": "The data/input string sent along with the transaction" + }, + { + "key": "logIndex", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The index of the event within its transaction, null when its pending" + }, + { + "key": "removed", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + }, + "description": "Whether or not the log was orphaned off the main chain" + }, + { + "key": "topics", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Topics" + } + } + }, + { + "key": "transactionHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + }, + { + "key": "transactionIndex", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionIndex" + } + } + } + ] + }, + "description": "An indexed event generated during a transaction" + }, + "Topics": { + "name": "LogTopics", + "shape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Topic" + } + } + } + }, + "description": "Topics are order-dependent. Each topic can also be an array of DATA with 'or' options." + }, + "Topic": { + "name": "Topic", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "32 Bytes DATA of indexed log arguments. (In solidity: The first topic is the hash of the signature of the event (e.g. Deposit(address,bytes32,uint256))" + }, + "TransactionIndex": { + "name": "TransactionIndex", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + }, + "description": "The index of the transaction. null when its pending" + }, + "BlockNumberOrNull": { + "name": "blockNumberOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + }, + "description": "The block number or null when its the pending block" + }, + "BlockHashOrNull": { + "name": "BlockHashOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "KeccakOrPending" + } + }, + "description": "The block hash or null when its the pending block" + }, + "NonceOrNull": { + "name": "nonceOrNull", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Nonce" + } + }, + "description": "Randomly selected number to satisfy the proof-of-work or null when its the pending block" + }, + "From": { + "name": "From", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "The sender of the transaction" + }, + "To": { + "name": "To", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "Destination address of the transaction. Null if it was a contract create." + }, + "Block": { + "name": "Block", + "shape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "number", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumberOrNull" + } + } + }, + { + "key": "hash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHashOrNull" + } + } + }, + { + "key": "parentHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "nonce", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "NonceOrNull" + } + } + }, + { + "key": "sha3Uncles", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "Keccak hash of the uncles data in the block" + }, + { + "key": "logsBloom", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The bloom filter for the logs of the block or null when its the pending block" + }, + { + "key": "transactionsRoot", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "The root of the transactions trie of the block." + }, + { + "key": "stateRoot", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "The root of the final state trie of the block" + }, + { + "key": "receiptsRoot", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "The root of the receipts trie of the block" + }, + { + "key": "miner", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "AddressOrNull" + } + } + }, + { + "key": "difficulty", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Integer of the difficulty for this block" + }, + { + "key": "totalDifficulty", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + }, + "description": "Integer of the total difficulty of the chain until this block" + }, + { + "key": "extraData", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The 'extra data' field of this block" + }, + { + "key": "size", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Integer the size of this block in bytes" + }, + { + "key": "gasLimit", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The maximum gas allowed in this block" + }, + { + "key": "gasUsed", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The total used gas by all transactions in this block" + }, + { + "key": "timestamp", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The unix timestamp for when the block was collated" + }, + { + "key": "transactions", + "valueShape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + }, + "description": "Array of transaction objects, or 32 Bytes transaction hashes depending on the last given parameter" + }, + { + "key": "uncles", + "valueShape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + } + } + }, + "description": "Array of uncle hashes" + } + ] + }, + "description": "The Block is the collection of relevant pieces of information (known as the block header), together with information corresponding to the comprised transactions, and a set of other block headers that are known to have a parent equal to the present block’s parent’s parent." + }, + "Transaction": { + "name": "transaction", + "shape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHashOrNull" + } + } + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumberOrNull" + } + } + } + } + }, + { + "key": "from", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "From" + } + } + } + } + }, + { + "key": "gas", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The gas limit provided by the sender in Wei" + }, + { + "key": "gasPrice", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "The gas price willing to be paid by the sender in Wei" + }, + { + "key": "hash", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + } + } + }, + { + "key": "input", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + } + } + }, + "description": "The data field sent with the transaction" + }, + { + "key": "nonce", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Nonce" + } + }, + "description": "The total number of prior transactions made by the sender" + }, + { + "key": "to", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "To" + } + } + } + } + }, + { + "key": "transactionIndex", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionIndex" + } + } + } + } + }, + { + "key": "value", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + } + } + }, + "description": "Value of Ether being transferred in Wei" + }, + { + "key": "v", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + } + } + }, + "description": "ECDSA recovery id" + }, + { + "key": "r", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + } + } + }, + "description": "ECDSA signature r" + }, + { + "key": "s", + "valueShape": { + "type": "alias", + "value": { + "type": "optional", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + } + } + }, + "description": "ECDSA signature s" + } + ] + } + }, + "Transactions": { + "name": "transactions", + "shape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + }, + "description": "An array of transactions" + }, + "TransactionHash": { + "name": "TransactionHash", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "Keccak 256 Hash of the RLP encoding of a transaction" + }, + "KeccakOrPending": { + "name": "keccakOrPending", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + } + }, + "Keccak": { + "name": "keccak", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Hex representation of a Keccak 256 hash" + }, + "Nonce": { + "name": "Nonce", + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "A number only to be used once" + }, + "Null": { + "name": "null", + "shape": { + "type": "alias", + "value": { + "type": "nullable", + "shape": { + "type": "alias", + "value": { + "type": "unknown", + "displayName": "null" + } + } + } + }, + "description": "Null" + }, + "Integer": { + "name": "integer", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Hex representation of the integer" + }, + "Address": { + "name": "address", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + } + }, + "Addresses": { + "name": "addresses", + "shape": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + } + }, + "description": "List of contract addresses from which to monitor events" + }, + "Position": { + "name": "position", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Hex representation of the storage slot where the variable exists" + }, + "DataWord": { + "name": "dataWord", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Hex representation of a 256 bit unit of data" + }, + "Bytes": { + "name": "bytes", + "shape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Hex representation of a variable length byte array" + } + }, + "endpoints": { + "web3_clientVersion": { + "id": "web3_clientVersion", + "displayName": "current client version", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Returns the version of the current client" + } + ], + "errors": [], + "description": "Returns the version of the current client", + "operationId": "web3_clientVersion", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "web3_sha3": { + "id": "web3_sha3", + "displayName": "Hashes data", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "data", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "data to hash using the Keccak-256 algorithm" + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "Hashes data using the Keccak-256 algorithm" + } + ], + "errors": [], + "examples": [ + { + "name": "sha3Example", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + "0x68656c6c6f20776f726c64" + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "sha3ResultExample", + "value": "0x47173285a8d7341e5e972fc677286384f802f8ef42a5ec5f03bbfa254cb01fad" + } + } + } + ], + "description": "Hashes data using the Keccak-256 algorithm", + "operationId": "web3_sha3", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "net_listening": { + "id": "net_listening", + "displayName": "returns listening status", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + }, + "description": "Determines if this client is listening for new network connections." + } + ], + "errors": [], + "examples": [ + { + "name": "netListeningTrueExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "netListeningExampleFalseResult", + "value": true + } + } + } + ], + "description": "Determines if this client is listening for new network connections.", + "operationId": "net_listening", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "net_peerCount": { + "id": "net_peerCount", + "displayName": "number of peers", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Returns the number of peers currently connected to this client." + } + ], + "errors": [], + "description": "Returns the number of peers currently connected to this client.", + "operationId": "net_peerCount", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "net_version": { + "id": "net_version", + "displayName": "Network identifier associated with network", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Returns the network ID associated with the current network." + } + ], + "errors": [], + "description": "Returns the network ID associated with the current network.", + "operationId": "net_version", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_blockNumber": { + "id": "eth_blockNumber", + "displayName": "Returns the number of most recent block.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ], + "errors": [], + "operationId": "eth_blockNumber", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_call": { + "id": "eth_call", + "displayName": "Executes a new message call (locally) immediately without creating a transaction on the block chain.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "transaction", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + } + } + ], + "errors": [], + "operationId": "eth_call", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_chainId": { + "id": "eth_chainId", + "displayName": "Returns the currently configured chain id", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "string" + } + } + }, + "description": "Returns the currently configured chain id, a value used in replay-protected transaction signing as introduced by [EIP-155](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md)." + } + ], + "errors": [], + "description": "Returns the currently configured chain id, a value used in replay-protected transaction signing as introduced by [EIP-155](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md).", + "operationId": "eth_chainId", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_coinbase": { + "id": "eth_coinbase", + "displayName": "Returns the client coinbase address.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + } + ], + "errors": [], + "operationId": "eth_coinbase", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_estimateGas": { + "id": "eth_estimateGas", + "displayName": "Generates and returns an estimate of how much gas is necessary to allow the transaction to complete. The transaction will not be added to the blockchain. Note that the estimate may be significantly more than the amount of gas actually used by the transaction, for a variety of reasons including EVM mechanics and node performance.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "transaction", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + } + ], + "errors": [], + "operationId": "eth_estimateGas", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_gasPrice": { + "id": "eth_gasPrice", + "displayName": "Returns the current price per gas in wei", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + } + ], + "errors": [], + "operationId": "eth_gasPrice", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getBalance": { + "id": "eth_getBalance", + "displayName": "Returns Ether balance of a given or account or contract", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "The address of the account or contract" + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + }, + "description": "A BlockNumber at which to request the balance" + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getBalance", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getBlockByHash": { + "id": "eth_getBlockByHash", + "displayName": "Gets a block for a given hash", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "includeTransactions", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + }, + "description": "If `true` it returns the full transaction objects, if `false` only the hashes of the transactions." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getBlockByHash", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getBlockByNumber": { + "id": "eth_getBlockByNumber", + "displayName": "Gets a block for a given number", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "includeTransactions", + "valueShape": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + }, + "description": "If `true` it returns the full transaction objects, if `false` only the hashes of the transactions." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getBlockByNumber", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getBlockTransactionCountByHash": { + "id": "eth_getBlockTransactionCountByHash", + "displayName": "Returns the number of transactions in a block from a block matching the given block hash.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getBlockTransactionCountByHash", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getBlockTransactionCountByNumber": { + "id": "eth_getBlockTransactionCountByNumber", + "displayName": "Returns the number of transactions in a block from a block matching the given block number.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getBlockTransactionCountByNumber", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getCode": { + "id": "eth_getCode", + "displayName": "Returns code at a given contract address", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "The address of the contract" + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + }, + "description": "A BlockNumber of which the code existed" + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + } + } + ], + "errors": [], + "operationId": "eth_getCode", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getFilterChanges": { + "id": "eth_getFilterChanges", + "displayName": "Polling method for a filter, which returns an array of logs which occurred since last poll.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "filterId", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "FilterId" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Log" + } + } + } + } + } + ], + "errors": [], + "operationId": "eth_getFilterChanges", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getFilterLogs": { + "id": "eth_getFilterLogs", + "displayName": "Returns an array of all logs matching filter with given id.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "filterId", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "FilterId" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Log" + } + } + } + } + } + ], + "errors": [], + "operationId": "eth_getFilterLogs", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getRawTransactionByHash": { + "id": "eth_getRawTransactionByHash", + "displayName": "Returns raw transaction data of a transaction with the given hash.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "transactionHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + } + } + ], + "errors": [], + "operationId": "eth_getRawTransactionByHash", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getRawTransactionByBlockHashAndIndex": { + "id": "eth_getRawTransactionByBlockHashAndIndex", + "displayName": "Returns raw transaction data of a transaction with the block hash and index of which it was mined.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a transaction is mined within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + } + } + ], + "errors": [], + "operationId": "eth_getRawTransactionByBlockHashAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getRawTransactionByBlockNumberAndIndex": { + "id": "eth_getRawTransactionByBlockNumberAndIndex", + "displayName": "Returns raw transaction data of a transaction with the block number and index of which it was mined.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a transaction is mined within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + } + } + ], + "errors": [], + "operationId": "eth_getRawTransactionByBlockNumberAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getLogs": { + "id": "eth_getLogs", + "displayName": "Returns an array of all logs matching a given filter object.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "filter", + "valueShape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "fromBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "toBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + }, + { + "key": "topics", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Topics" + } + } + } + ] + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Log" + } + } + } + } + } + ], + "errors": [], + "operationId": "eth_getLogs", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getStorageAt": { + "id": "eth_getStorageAt", + "displayName": "Gets a storage value from a contract address, a position, and an optional blockNumber", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + }, + { + "key": "key", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Position" + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + } + } + ], + "errors": [], + "operationId": "eth_getStorageAt", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getTransactionByBlockHashAndIndex": { + "id": "eth_getTransactionByBlockHashAndIndex", + "displayName": "Returns the information about a transaction requested by the block hash and index of which it was mined.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a transaction is mined within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + ], + "errors": [], + "examples": [ + { + "name": "nullExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + "0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef", + "0x0" + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "nullResultExample", + "value": null + } + } + } + ], + "operationId": "eth_getTransactionByBlockHashAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getTransactionByBlockNumberAndIndex": { + "id": "eth_getTransactionByBlockNumberAndIndex", + "displayName": "Returns the information about a transaction requested by the block number and index of which it was mined.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a transaction is mined within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + ], + "errors": [], + "operationId": "eth_getTransactionByBlockNumberAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getTransactionByHash": { + "id": "eth_getTransactionByHash", + "displayName": "Returns the information about a transaction requested by transaction hash.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "transactionHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Transaction" + } + } + } + ], + "errors": [], + "operationId": "eth_getTransactionByHash", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getTransactionCount": { + "id": "eth_getTransactionCount", + "displayName": "Returns the number of transactions sent from an address", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Nonce" + } + } + } + ], + "errors": [], + "operationId": "eth_getTransactionCount", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getTransactionReceipt": { + "id": "eth_getTransactionReceipt", + "displayName": "Returns the receipt information of a transaction by its hash.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "transactionHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "TransactionHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Receipt" + } + } + } + ], + "errors": [], + "operationId": "eth_getTransactionReceipt", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getUncleByBlockHashAndIndex": { + "id": "eth_getUncleByBlockHashAndIndex", + "displayName": "Returns information about a uncle of a block by hash and uncle index position.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a uncle is included within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getUncleByBlockHashAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getUncleByBlockNumberAndIndex": { + "id": "eth_getUncleByBlockNumberAndIndex", + "displayName": "Returns information about a uncle of a block by hash and uncle index position.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "uncleBlockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + }, + "description": "The block in which the uncle was included" + }, + { + "key": "index", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The ordering in which a uncle is included within its block." + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockOrNull" + } + } + } + ], + "errors": [], + "examples": [ + { + "name": "nullResultExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + "0x0", + "0x0" + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "nullResultExample", + "value": null + } + } + } + ], + "operationId": "eth_getUncleByBlockNumberAndIndex", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getUncleCountByBlockHash": { + "id": "eth_getUncleCountByBlockHash", + "displayName": "Returns the number of uncles in a block from a block matching the given block hash.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getUncleCountByBlockHash", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getUncleCountByBlockNumber": { + "id": "eth_getUncleCountByBlockNumber", + "displayName": "Returns the number of uncles in a block from a block matching the given block number.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "IntegerOrNull" + } + } + } + ], + "errors": [], + "operationId": "eth_getUncleCountByBlockNumber", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getProof": { + "id": "eth_getProof", + "displayName": "Returns the account- and storage-values of the specified account including the Merkle-proof.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "The address of the account or contract" + }, + { + "key": "blockNumber", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + }, + "description": "The address of the account or contract of the request" + }, + { + "key": "accountProof", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "ProofNodes" + } + } + }, + { + "key": "balance", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The Ether balance of the account or contract of the request" + }, + { + "key": "codeHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "The code hash of the contract of the request (keccak(NULL) if external account)" + }, + { + "key": "nonce", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Nonce" + } + }, + "description": "The transaction count of the account or contract of the request" + }, + { + "key": "storageHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + }, + "description": "The storage hash of the contract of the request (keccak(rlp(NULL)) if external account)" + }, + { + "key": "storageProof", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "StorageProof" + } + } + } + ] + } + } + ], + "errors": [], + "operationId": "eth_getProof", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_getWork": { + "id": "eth_getWork", + "displayName": "Returns the hash of the current block, the seedHash, and the boundary condition to be met ('target').", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "list", + "itemShape": { + "type": "undiscriminatedUnion", + "variants": [ + { + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "PowHash" + } + } + }, + { + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "SeedHash" + } + } + }, + { + "shape": { + "type": "alias", + "value": { + "type": "id", + "id": "Difficulty" + } + } + } + ] + } + } + } + } + ], + "errors": [], + "operationId": "eth_getWork", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_hashrate": { + "id": "eth_hashrate", + "displayName": "Returns the number of hashes per second that the node is mining with.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + } + ], + "errors": [], + "operationId": "eth_hashrate", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_mining": { + "id": "eth_mining", + "displayName": "Returns true if client is actively mining new blocks.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + } + } + ], + "errors": [], + "operationId": "eth_mining", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_newBlockFilter": { + "id": "eth_newBlockFilter", + "displayName": "Creates a filter in the node, to notify when a new block arrives. To check if the state has changed, call eth_getFilterChanges.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "FilterId" + } + } + } + ], + "errors": [], + "operationId": "eth_newBlockFilter", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_newFilter": { + "id": "eth_newFilter", + "displayName": "Creates a filter object, based on filter options, to notify when the state changes (logs). To check if the state has changed, call eth_getFilterChanges.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "filter", + "valueShape": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "fromBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "toBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "BlockNumber" + } + } + }, + { + "key": "address", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Address" + } + } + }, + { + "key": "topics", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Topics" + } + } + } + ] + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + } + ], + "errors": [], + "operationId": "eth_newFilter", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_newPendingTransactionFilter": { + "id": "eth_newPendingTransactionFilter", + "displayName": "Creates a filter in the node, to notify when new pending transactions arrive. To check if the state has changed, call eth_getFilterChanges.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "FilterId" + } + } + } + ], + "errors": [], + "operationId": "eth_newPendingTransactionFilter", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_pendingTransactions": { + "id": "eth_pendingTransactions", + "displayName": "Returns the transactions that are pending in the transaction pool and have a from address that is one of the accounts this node manages.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Transactions" + } + } + } + ], + "errors": [], + "operationId": "eth_pendingTransactions", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_protocolVersion": { + "id": "eth_protocolVersion", + "displayName": "Returns the current ethereum protocol version.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + } + } + ], + "errors": [], + "operationId": "eth_protocolVersion", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_sendRawTransaction": { + "id": "eth_sendRawTransaction", + "displayName": "Creates new message call transaction or a contract creation for signed transactions.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "signedTransactionData", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Bytes" + } + }, + "description": "The signed transaction data" + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "id", + "id": "Keccak" + } + } + } + ], + "errors": [], + "operationId": "eth_sendRawTransaction", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_submitHashrate": { + "id": "eth_submitHashrate", + "displayName": "Used for submitting mining hashrate.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "hashRate", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + } + }, + { + "key": "id", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "DataWord" + } + }, + "description": "String identifying the client" + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + } + } + ], + "errors": [], + "operationId": "eth_submitHashrate", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_submitWork": { + "id": "eth_submitWork", + "displayName": "Used for submitting a proof-of-work solution.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "nonce", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Nonce" + } + } + }, + { + "key": "powHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "PowHash" + } + } + }, + { + "key": "mixHash", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "MixHash" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + } + } + ], + "errors": [], + "examples": [ + { + "name": "submitWorkExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + "0x0000000000000001", + "0x6bf2cAE0dE3ec3ecA5E194a6C6e02cf42aADfe1C2c4Fff12E5D36C3Cf7297F22", + "0xD1FE5700000000000000000000000000D1FE5700000000000000000000000000" + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "solutionInvalidExample", + "description": "this example should return `false` as it is not a valid pow to submit", + "value": false + } + } + } + ], + "operationId": "eth_submitWork", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_syncing": { + "id": "eth_syncing", + "displayName": "Returns an object with data about the sync status or false.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "startingBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "Block at which the import started (will only be reset, after the sync reached his head)" + }, + { + "key": "currentBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The current block, same as eth_blockNumber" + }, + { + "key": "highestBlock", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The estimated highest block" + }, + { + "key": "knownStates", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The known states" + }, + { + "key": "pulledStates", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "Integer" + } + }, + "description": "The pulled states" + } + ] + } + } + ], + "errors": [], + "operationId": "eth_syncing", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + }, + "eth_uninstallFilter": { + "id": "eth_uninstallFilter", + "displayName": "Uninstalls a filter with given id. Should always be called when watch is no longer needed. Additionally Filters timeout when they aren't requested with eth_getFilterChanges for a period of time.", + "method": "POST", + "path": [ + { + "type": "literal", + "value": "" + } + ], + "pathParameters": [], + "queryParameters": [], + "requests": [ + { + "contentType": "application/json", + "body": { + "type": "object", + "extends": [], + "properties": [ + { + "key": "filterId", + "valueShape": { + "type": "alias", + "value": { + "type": "id", + "id": "FilterId" + } + } + } + ] + } + } + ], + "responses": [ + { + "statusCode": 200, + "body": { + "type": "alias", + "value": { + "type": "primitive", + "value": { + "type": "boolean" + } + } + } + } + ], + "errors": [], + "operationId": "eth_uninstallFilter", + "environments": [], + "requestHeaders": [], + "responseHeaders": [], + "namespace": [] + } + }, + "websockets": {}, + "webhooks": {}, + "subpackages": {}, + "auths": {}, + "globalHeaders": [] +} \ No newline at end of file diff --git a/packages/parsers/src/openrpc/__test__/__snapshots__/petstore.json b/packages/parsers/src/openrpc/__test__/__snapshots__/petstore.json index 5a2f75d424..4ce686ce0c 100644 --- a/packages/parsers/src/openrpc/__test__/__snapshots__/petstore.json +++ b/packages/parsers/src/openrpc/__test__/__snapshots__/petstore.json @@ -131,7 +131,35 @@ } ], "errors": [], - "examples": [], + "examples": [ + { + "name": "listPetExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + 1 + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "listPetResultExample", + "value": [ + { + "id": 7, + "name": "fluffy", + "tag": "poodle" + } + ] + } + } + } + ], "operationId": "list_pets", "environments": [], "requestHeaders": [], @@ -200,7 +228,30 @@ } ], "errors": [], - "examples": [], + "examples": [ + { + "name": "createPetExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + "fluffy", + "poodle" + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "listPetResultExample", + "value": 7 + } + } + } + ], "operationId": "create_pet", "environments": [], "requestHeaders": [], @@ -254,7 +305,33 @@ } ], "errors": [], - "examples": [], + "examples": [ + { + "name": "getPetExample", + "path": "", + "pathParameters": {}, + "queryParameters": {}, + "headers": {}, + "requestBody": { + "type": "json", + "value": [ + 7 + ] + }, + "responseStatusCode": 200, + "responseBody": { + "type": "json", + "value": { + "name": "getPetExampleResult", + "value": { + "name": "fluffy", + "tag": "poodle", + "id": 7 + } + } + } + } + ], "operationId": "get_pet", "environments": [], "requestHeaders": [], diff --git a/packages/parsers/src/openrpc/__test__/fixtures/ethereum/openrpc.json b/packages/parsers/src/openrpc/__test__/fixtures/ethereum/openrpc.json new file mode 100644 index 0000000000..3e66fb864c --- /dev/null +++ b/packages/parsers/src/openrpc/__test__/fixtures/ethereum/openrpc.json @@ -0,0 +1,1786 @@ +{ + "openrpc": "1.0.0", + "info": { + "version": "1.0.10", + "title": "Ethereum JSON-RPC", + "description": "This API lets you interact with an EVM-based client via JSON-RPC", + "license": { + "name": "Apache 2.0", + "url": "https://www.apache.org/licenses/LICENSE-2.0.html" + } + }, + "methods": [ + { + "name": "web3_clientVersion", + "description": "Returns the version of the current client", + "summary": "current client version", + "params": [], + "result": { + "name": "clientVersion", + "description": "client version", + "schema": { + "title": "clientVersion", + "type": "string" + } + } + }, + { + "name": "web3_sha3", + "summary": "Hashes data", + "description": "Hashes data using the Keccak-256 algorithm", + "params": [ + { + "name": "data", + "description": "data to hash using the Keccak-256 algorithm", + "summary": "data to hash", + "schema": { + "title": "data", + "type": "string", + "pattern": "^0x[a-fA-F\\d]+$" + } + } + ], + "result": { + "name": "hashedData", + "description": "Keccak-256 hash of the given data", + "schema": { + "$ref": "#/components/schemas/Keccak" + } + }, + "examples": [ + { + "name": "sha3Example", + "params": [ + { + "name": "sha3ParamExample", + "value": "0x68656c6c6f20776f726c64" + } + ], + "result": { + "name": "sha3ResultExample", + "value": "0x47173285a8d7341e5e972fc677286384f802f8ef42a5ec5f03bbfa254cb01fad" + } + } + ] + }, + { + "name": "net_listening", + "summary": "returns listening status", + "description": "Determines if this client is listening for new network connections.", + "params": [], + "result": { + "name": "netListeningResult", + "description": "`true` if listening is active or `false` if listening is not active", + "schema": { + "title": "isNetListening", + "type": "boolean" + } + }, + "examples": [ + { + "name": "netListeningTrueExample", + "description": "example of true result for net_listening", + "params": [], + "result": { + "name": "netListeningExampleFalseResult", + "value": true + } + } + ] + }, + { + "name": "net_peerCount", + "summary": "number of peers", + "description": "Returns the number of peers currently connected to this client.", + "params": [], + "result": { + "name": "quantity", + "description": "number of connected peers.", + "schema": { + "title": "numConnectedPeers", + "description": "Hex representation of number of connected peers", + "type": "string" + } + } + }, + { + "name": "net_version", + "summary": "Network identifier associated with network", + "description": "Returns the network ID associated with the current network.", + "params": [], + "result": { + "name": "networkId", + "description": "Network ID associated with the current network", + "schema": { + "title": "networkId", + "type": "string", + "pattern": "^[\\d]+$" + } + } + }, + { + "name": "eth_blockNumber", + "summary": "Returns the number of most recent block.", + "params": [], + "result": { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + }, + { + "name": "eth_call", + "summary": "Executes a new message call (locally) immediately without creating a transaction on the block chain.", + "params": [ + { + "$ref": "#/components/contentDescriptors/Transaction" + }, + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "name": "returnValue", + "description": "The return value of the executed contract", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + }, + { + "name": "eth_chainId", + "summary": "Returns the currently configured chain id", + "description": "Returns the currently configured chain id, a value used in replay-protected transaction signing as introduced by [EIP-155](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md).", + "params": [], + "result": { + "name": "chainId", + "description": "hex format integer of the current chain id. Defaults are ETC=61, ETH=1, Morden=62.", + "schema": { + "title": "chainId", + "type": "string", + "pattern": "^0x[a-fA-F\\d]+$" + } + } + }, + { + "name": "eth_coinbase", + "summary": "Returns the client coinbase address.", + "params": [], + "result": { + "name": "address", + "description": "The address owned by the client that is used as default for things like the mining reward", + "schema": { + "$ref": "#/components/schemas/Address" + } + } + }, + { + "name": "eth_estimateGas", + "summary": "Generates and returns an estimate of how much gas is necessary to allow the transaction to complete. The transaction will not be added to the blockchain. Note that the estimate may be significantly more than the amount of gas actually used by the transaction, for a variety of reasons including EVM mechanics and node performance.", + "params": [ + { + "$ref": "#/components/contentDescriptors/Transaction" + } + ], + "result": { + "name": "gasUsed", + "description": "The amount of gas used", + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + }, + { + "name": "eth_gasPrice", + "summary": "Returns the current price per gas in wei", + "params": [], + "result": { + "$ref": "#/components/contentDescriptors/GasPrice" + } + }, + { + "name": "eth_getBalance", + "summary": "Returns Ether balance of a given or account or contract", + "params": [ + { + "name": "address", + "required": true, + "description": "The address of the account or contract", + "schema": { + "$ref": "#/components/schemas/Address" + } + }, + { + "name": "blockNumber", + "description": "A BlockNumber at which to request the balance", + "schema": { + "$ref": "#/components/schemas/BlockNumber" + } + } + ], + "result": { + "name": "getBalanceResult", + "schema": { + "$ref": "#/components/schemas/IntegerOrNull" + } + } + }, + { + "name": "eth_getBlockByHash", + "summary": "Gets a block for a given hash", + "params": [ + { + "name": "blockHash", + "required": true, + "schema": { + "$ref": "#/components/schemas/BlockHash" + } + }, + { + "name": "includeTransactions", + "description": "If `true` it returns the full transaction objects, if `false` only the hashes of the transactions.", + "required": true, + "schema": { + "title": "isTransactionsIncluded", + "type": "boolean" + } + } + ], + "result": { + "name": "getBlockByHashResult", + "schema": { + "$ref": "#/components/schemas/BlockOrNull" + } + } + }, + { + "name": "eth_getBlockByNumber", + "summary": "Gets a block for a given number", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockNumber" + }, + { + "name": "includeTransactions", + "description": "If `true` it returns the full transaction objects, if `false` only the hashes of the transactions.", + "required": true, + "schema": { + "title": "isTransactionsIncluded", + "type": "boolean" + } + } + ], + "result": { + "name": "getBlockByNumberResult", + "schema": { + "$ref": "#/components/schemas/BlockOrNull" + } + } + }, + { + "name": "eth_getBlockTransactionCountByHash", + "summary": "Returns the number of transactions in a block from a block matching the given block hash.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockHash" + } + ], + "result": { + "name": "blockTransactionCountByHash", + "description": "The Number of total transactions in the given block", + "schema": { + "$ref": "#/components/schemas/IntegerOrNull" + } + } + }, + { + "name": "eth_getBlockTransactionCountByNumber", + "summary": "Returns the number of transactions in a block from a block matching the given block number.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "name": "blockTransactionCountByHash", + "description": "The Number of total transactions in the given block", + "schema": { + "$ref": "#/components/schemas/IntegerOrNull" + } + } + }, + { + "name": "eth_getCode", + "summary": "Returns code at a given contract address", + "params": [ + { + "name": "address", + "required": true, + "description": "The address of the contract", + "schema": { + "$ref": "#/components/schemas/Address" + } + }, + { + "name": "blockNumber", + "description": "A BlockNumber of which the code existed", + "schema": { + "$ref": "#/components/schemas/BlockNumber" + } + } + ], + "result": { + "name": "bytes", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + }, + { + "name": "eth_getFilterChanges", + "summary": "Polling method for a filter, which returns an array of logs which occurred since last poll.", + "params": [ + { + "name": "filterId", + "required": true, + "schema": { + "$ref": "#/components/schemas/FilterId" + } + } + ], + "result": { + "name": "logResult", + "schema": { + "title": "logResult", + "type": "array", + "items": { + "$ref": "#/components/schemas/Log" + } + } + } + }, + { + "name": "eth_getFilterLogs", + "summary": "Returns an array of all logs matching filter with given id.", + "params": [ + { + "name": "filterId", + "required": true, + "schema": { + "$ref": "#/components/schemas/FilterId" + } + } + ], + "result": { + "$ref": "#/components/contentDescriptors/Logs" + } + }, + { + "name": "eth_getRawTransactionByHash", + "summary": "Returns raw transaction data of a transaction with the given hash.", + "params": [ + { + "$ref": "#/components/contentDescriptors/TransactionHash" + } + ], + "result": { + "name": "rawTransactionByHash", + "description": "The raw transaction data", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + }, + { + "name": "eth_getRawTransactionByBlockHashAndIndex", + "summary": "Returns raw transaction data of a transaction with the block hash and index of which it was mined.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockHash" + }, + { + "name": "index", + "description": "The ordering in which a transaction is mined within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "name": "rawTransaction", + "description": "The raw transaction data", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + }, + { + "name": "eth_getRawTransactionByBlockNumberAndIndex", + "summary": "Returns raw transaction data of a transaction with the block number and index of which it was mined.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockNumber" + }, + { + "name": "index", + "description": "The ordering in which a transaction is mined within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "name": "rawTransaction", + "description": "The raw transaction data", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + }, + { + "name": "eth_getLogs", + "summary": "Returns an array of all logs matching a given filter object.", + "params": [ + { + "$ref": "#/components/contentDescriptors/Filter" + } + ], + "result": { + "$ref": "#/components/contentDescriptors/Logs" + } + }, + { + "name": "eth_getStorageAt", + "summary": "Gets a storage value from a contract address, a position, and an optional blockNumber", + "params": [ + { + "$ref": "#/components/contentDescriptors/Address" + }, + { + "$ref": "#/components/contentDescriptors/Position" + }, + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "name": "dataWord", + "schema": { + "$ref": "#/components/schemas/DataWord" + } + } + }, + { + "name": "eth_getTransactionByBlockHashAndIndex", + "summary": "Returns the information about a transaction requested by the block hash and index of which it was mined.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockHash" + }, + { + "name": "index", + "description": "The ordering in which a transaction is mined within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "$ref": "#/components/contentDescriptors/TransactionResult" + }, + "examples": [ + { + "name": "nullExample", + "params": [ + { + "name": "blockHashExample", + "value": "0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef" + }, + { + "name": "indexExample", + "value": "0x0" + } + ], + "result": { + "name": "nullResultExample", + "value": null + } + } + ] + }, + { + "name": "eth_getTransactionByBlockNumberAndIndex", + "summary": "Returns the information about a transaction requested by the block number and index of which it was mined.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockNumber" + }, + { + "name": "index", + "description": "The ordering in which a transaction is mined within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "$ref": "#/components/contentDescriptors/TransactionResult" + } + }, + { + "name": "eth_getTransactionByHash", + "summary": "Returns the information about a transaction requested by transaction hash.", + "params": [ + { + "$ref": "#/components/contentDescriptors/TransactionHash" + } + ], + "result": { + "$ref": "#/components/contentDescriptors/TransactionResult" + } + }, + { + "name": "eth_getTransactionCount", + "summary": "Returns the number of transactions sent from an address", + "params": [ + { + "$ref": "#/components/contentDescriptors/Address" + }, + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "name": "transactionCount", + "schema": { + "title": "nonceOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Nonce" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + } + } + }, + { + "name": "eth_getTransactionReceipt", + "summary": "Returns the receipt information of a transaction by its hash.", + "params": [ + { + "$ref": "#/components/contentDescriptors/TransactionHash" + } + ], + "result": { + "name": "transactionReceiptResult", + "description": "returns either a receipt or null", + "schema": { + "title": "transactionReceiptOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Receipt" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + } + } + }, + { + "name": "eth_getUncleByBlockHashAndIndex", + "summary": "Returns information about a uncle of a block by hash and uncle index position.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockHash" + }, + { + "name": "index", + "description": "The ordering in which a uncle is included within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "name": "uncle", + "schema": { + "$ref": "#/components/schemas/BlockOrNull" + } + } + }, + { + "name": "eth_getUncleByBlockNumberAndIndex", + "summary": "Returns information about a uncle of a block by hash and uncle index position.", + "params": [ + { + "name": "uncleBlockNumber", + "description": "The block in which the uncle was included", + "required": true, + "schema": { + "$ref": "#/components/schemas/BlockNumber" + } + }, + { + "name": "index", + "description": "The ordering in which a uncle is included within its block.", + "required": true, + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + ], + "result": { + "name": "uncleResult", + "description": "returns an uncle block or null", + "schema": { + "$ref": "#/components/schemas/BlockOrNull" + } + }, + "examples": [ + { + "name": "nullResultExample", + "params": [ + { + "name": "uncleBlockNumberExample", + "value": "0x0" + }, + { + "name": "uncleBlockNumberIndexExample", + "value": "0x0" + } + ], + "result": { + "name": "nullResultExample", + "value": null + } + } + ] + }, + { + "name": "eth_getUncleCountByBlockHash", + "summary": "Returns the number of uncles in a block from a block matching the given block hash.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockHash" + } + ], + "result": { + "name": "uncleCountResult", + "description": "The Number of total uncles in the given block", + "schema": { + "$ref": "#/components/schemas/IntegerOrNull" + } + } + }, + { + "name": "eth_getUncleCountByBlockNumber", + "summary": "Returns the number of uncles in a block from a block matching the given block number.", + "params": [ + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "$ref": "#/components/contentDescriptors/UncleCountResult" + } + }, + { + "name": "eth_getProof", + "summary": "Returns the account- and storage-values of the specified account including the Merkle-proof.", + "params": [ + { + "name": "address", + "description": "The address of the account or contract", + "required": true, + "schema": { + "$ref": "#/components/schemas/Address" + } + }, + { + "name": "storageKeys", + "required": true, + "schema": { + "title": "storageKeys", + "description": "A storage key is indexed from the solidity compiler by the order it is declared. For mappings it uses the keccak of the mapping key with its position (and recursively for X-dimensional mappings)", + "items": { + "$ref": "#/components/schemas/StorageProofKey" + } + } + }, + { + "$ref": "#/components/contentDescriptors/BlockNumber" + } + ], + "result": { + "name": "account", + "schema": { + "title": "proofAccountOrNull", + "oneOf": [ + { + "title": "proofAccount", + "type": "object", + "description": "The merkle proofs of the specified account connecting them to the blockhash of the block specified", + "properties": { + "address": { + "title": "proofAccountAddress", + "description": "The address of the account or contract of the request", + "$ref": "#/components/schemas/Address" + }, + "accountProof": { + "$ref": "#/components/schemas/ProofNodes" + }, + "balance": { + "title": "proofAccountBalance", + "description": "The Ether balance of the account or contract of the request", + "$ref": "#/components/schemas/Integer" + }, + "codeHash": { + "title": "proofAccountCodeHash", + "description": "The code hash of the contract of the request (keccak(NULL) if external account)", + "$ref": "#/components/schemas/Keccak" + }, + "nonce": { + "title": "proofAccountNonce", + "description": "The transaction count of the account or contract of the request", + "$ref": "#/components/schemas/Nonce" + }, + "storageHash": { + "title": "proofAccountStorageHash", + "description": "The storage hash of the contract of the request (keccak(rlp(NULL)) if external account)", + "$ref": "#/components/schemas/Keccak" + }, + "storageProof": { + "$ref": "#/components/schemas/StorageProof" + } + } + }, + { + "$ref": "#/components/schemas/Null" + } + ] + } + } + }, + { + "name": "eth_getWork", + "summary": "Returns the hash of the current block, the seedHash, and the boundary condition to be met ('target').", + "params": [], + "result": { + "name": "work", + "schema": { + "title": "getWorkResults", + "type": "array", + "items": [ + { + "$ref": "#/components/schemas/PowHash" + }, + { + "$ref": "#/components/schemas/SeedHash" + }, + { + "$ref": "#/components/schemas/Difficulty" + } + ] + } + } + }, + { + "name": "eth_hashrate", + "summary": "Returns the number of hashes per second that the node is mining with.", + "params": [], + "result": { + "name": "hashesPerSecond", + "description": "Integer of the number of hashes per second", + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + }, + { + "name": "eth_mining", + "summary": "Returns true if client is actively mining new blocks.", + "params": [], + "result": { + "name": "mining", + "description": "Whether or not the client is mining", + "schema": { + "type": "boolean" + } + } + }, + { + "name": "eth_newBlockFilter", + "summary": "Creates a filter in the node, to notify when a new block arrives. To check if the state has changed, call eth_getFilterChanges.", + "params": [], + "result": { + "$ref": "#/components/contentDescriptors/FilterId" + } + }, + { + "name": "eth_newFilter", + "summary": "Creates a filter object, based on filter options, to notify when the state changes (logs). To check if the state has changed, call eth_getFilterChanges.", + "params": [ + { + "$ref": "#/components/contentDescriptors/Filter" + } + ], + "result": { + "name": "filterId", + "description": "The filter ID for use in `eth_getFilterChanges`", + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + }, + { + "name": "eth_newPendingTransactionFilter", + "summary": "Creates a filter in the node, to notify when new pending transactions arrive. To check if the state has changed, call eth_getFilterChanges.", + "params": [], + "result": { + "$ref": "#/components/contentDescriptors/FilterId" + } + }, + { + "name": "eth_pendingTransactions", + "summary": "Returns the transactions that are pending in the transaction pool and have a from address that is one of the accounts this node manages.", + "params": [], + "result": { + "name": "pendingTransactions", + "schema": { + "$ref": "#/components/schemas/Transactions" + } + } + }, + { + "name": "eth_protocolVersion", + "summary": "Returns the current ethereum protocol version.", + "params": [], + "result": { + "name": "protocolVersion", + "description": "The current ethereum protocol version", + "schema": { + "$ref": "#/components/schemas/Integer" + } + } + }, + { + "name": "eth_sendRawTransaction", + "summary": "Creates new message call transaction or a contract creation for signed transactions.", + "params": [ + { + "name": "signedTransactionData", + "required": true, + "description": "The signed transaction data", + "schema": { + "$ref": "#/components/schemas/Bytes" + } + } + ], + "result": { + "name": "transactionHash", + "description": "The transaction hash, or the zero hash if the transaction is not yet available.", + "schema": { + "$ref": "#/components/schemas/Keccak" + } + } + }, + { + "name": "eth_submitHashrate", + "deprecated": true, + "summary": "Used for submitting mining hashrate.", + "params": [ + { + "name": "hashRate", + "required": true, + "schema": { + "$ref": "#/components/schemas/DataWord" + } + }, + { + "name": "id", + "required": true, + "description": "String identifying the client", + "schema": { + "$ref": "#/components/schemas/DataWord" + } + } + ], + "result": { + "name": "submitHashRateSuccess", + "description": "whether of not submitting went through successfully", + "schema": { + "type": "boolean" + } + } + }, + { + "name": "eth_submitWork", + "summary": "Used for submitting a proof-of-work solution.", + "params": [ + { + "$ref": "#/components/contentDescriptors/Nonce" + }, + { + "name": "powHash", + "required": true, + "schema": { + "$ref": "#/components/schemas/PowHash" + } + }, + { + "name": "mixHash", + "required": true, + "schema": { + "$ref": "#/components/schemas/MixHash" + } + } + ], + "result": { + "name": "solutionValid", + "description": "returns true if the provided solution is valid, otherwise false.", + "schema": { + "type": "boolean" + } + }, + "examples": [ + { + "name": "submitWorkExample", + "params": [ + { + "name": "nonceExample", + "description": "example of a number only used once", + "value": "0x0000000000000001" + }, + { + "name": "powHashExample", + "description": "proof of work to submit", + "value": "0x6bf2cAE0dE3ec3ecA5E194a6C6e02cf42aADfe1C2c4Fff12E5D36C3Cf7297F22" + }, + { + "name": "mixHashExample", + "description": "the mix digest example", + "value": "0xD1FE5700000000000000000000000000D1FE5700000000000000000000000000" + } + ], + "result": { + "name": "solutionInvalidExample", + "description": "this example should return `false` as it is not a valid pow to submit", + "value": false + } + } + ] + }, + { + "name": "eth_syncing", + "summary": "Returns an object with data about the sync status or false.", + "params": [], + "result": { + "name": "syncing", + "schema": { + "title": "isSyncingResult", + "oneOf": [ + { + "title": "syncingData", + "description": "An object with sync status data", + "type": "object", + "properties": { + "startingBlock": { + "title": "syncingDataStartingBlock", + "description": "Block at which the import started (will only be reset, after the sync reached his head)", + "$ref": "#/components/schemas/Integer" + }, + "currentBlock": { + "title": "syncingDataCurrentBlock", + "description": "The current block, same as eth_blockNumber", + "$ref": "#/components/schemas/Integer" + }, + "highestBlock": { + "title": "syncingDataHighestBlock", + "description": "The estimated highest block", + "$ref": "#/components/schemas/Integer" + }, + "knownStates": { + "title": "syncingDataKnownStates", + "description": "The known states", + "$ref": "#/components/schemas/Integer" + }, + "pulledStates": { + "title": "syncingDataPulledStates", + "description": "The pulled states", + "$ref": "#/components/schemas/Integer" + } + } + }, + { + "type": "boolean" + } + ] + } + } + }, + { + "name": "eth_uninstallFilter", + "summary": "Uninstalls a filter with given id. Should always be called when watch is no longer needed. Additionally Filters timeout when they aren't requested with eth_getFilterChanges for a period of time.", + "params": [ + { + "name": "filterId", + "required": true, + "schema": { + "$ref": "#/components/schemas/FilterId" + } + } + ], + "result": { + "name": "filterUninstalledSuccess", + "description": "returns true if the filter was successfully uninstalled, false otherwise.", + "schema": { + "type": "boolean" + } + } + } + ], + "components": { + "schemas": { + "ProofNode": { + "title": "proofNode", + "description": "An individual node used to prove a path down a merkle-patricia-tree", + "$ref": "#/components/schemas/Bytes" + }, + "StorageProofKey": { + "title": "storageProofKey", + "description": "The key used to get the storage slot in its account tree.", + "$ref": "#/components/schemas/Integer" + }, + "StorageProof": { + "title": "storageProofSet", + "type": "array", + "description": "Current block header PoW hash.", + "items": { + "title": "storageProof", + "type": "object", + "description": "Object proving a relationship of a storage value to an account's storageHash.", + "properties": { + "key": { + "$ref": "#/components/schemas/StorageProofKey" + }, + "value": { + "title": "storageProofValue", + "description": "The value of the storage slot in its account tree", + "$ref": "#/components/schemas/Integer" + }, + "proof": { + "$ref": "#/components/schemas/ProofNodes" + } + } + } + }, + "ProofNodes": { + "title": "proofNodes", + "type": "array", + "description": "The set of node values needed to traverse a patricia merkle tree (from root to leaf) to retrieve a value", + "items": { + "$ref": "#/components/schemas/ProofNode" + } + }, + "PowHash": { + "title": "powHash", + "description": "Current block header PoW hash.", + "$ref": "#/components/schemas/DataWord" + }, + "SeedHash": { + "title": "seedHash", + "description": "The seed hash used for the DAG.", + "$ref": "#/components/schemas/DataWord" + }, + "MixHash": { + "title": "mixHash", + "description": "The mix digest.", + "$ref": "#/components/schemas/DataWord" + }, + "Difficulty": { + "title": "difficulty", + "description": "The boundary condition ('target'), 2^256 / difficulty.", + "$ref": "#/components/schemas/DataWord" + }, + "FilterId": { + "title": "filterId", + "type": "string", + "description": "An identifier used to reference the filter." + }, + "BlockHash": { + "title": "blockHash", + "type": "string", + "pattern": "^0x[a-fA-F\\d]{64}$", + "description": "The hex representation of the Keccak 256 of the RLP encoded block" + }, + "BlockNumber": { + "title": "blockNumber", + "type": "string", + "description": "The hex representation of the block's height", + "$ref": "#/components/schemas/Integer" + }, + "BlockNumberTag": { + "title": "blockNumberTag", + "type": "string", + "description": "The optional block height description", + "enum": [ + "earliest", + "latest", + "pending" + ] + }, + "BlockOrNull": { + "title": "blockOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Block" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "IntegerOrNull": { + "title": "integerOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Integer" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "AddressOrNull": { + "title": "addressOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Address" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "Receipt": { + "title": "receipt", + "type": "object", + "description": "The receipt of a transaction", + "required": [ + "blockHash", + "blockNumber", + "contractAddress", + "cumulativeGasUsed", + "from", + "gasUsed", + "logs", + "logsBloom", + "to", + "transactionHash", + "transactionIndex" + ], + "properties": { + "blockHash": { + "$ref": "#/components/schemas/BlockHash" + }, + "blockNumber": { + "$ref": "#/components/schemas/BlockNumber" + }, + "contractAddress": { + "title": "ReceiptContractAddress", + "description": "The contract address created, if the transaction was a contract creation, otherwise null", + "$ref": "#/components/schemas/AddressOrNull" + }, + "cumulativeGasUsed": { + "title": "ReceiptCumulativeGasUsed", + "description": "The gas units used by the transaction", + "$ref": "#/components/schemas/Integer" + }, + "from": { + "$ref": "#/components/schemas/From" + }, + "gasUsed": { + "title": "ReceiptGasUsed", + "description": "The total gas used by the transaction", + "$ref": "#/components/schemas/Integer" + }, + "logs": { + "title": "logs", + "type": "array", + "description": "An array of all the logs triggered during the transaction", + "items": { + "$ref": "#/components/schemas/Log" + } + }, + "logsBloom": { + "$ref": "#/components/schemas/BloomFilter" + }, + "to": { + "$ref": "#/components/schemas/To" + }, + "transactionHash": { + "$ref": "#/components/schemas/TransactionHash" + }, + "transactionIndex": { + "$ref": "#/components/schemas/TransactionIndex" + }, + "postTransactionState": { + "title": "ReceiptPostTransactionState", + "description": "The intermediate stateRoot directly after transaction execution.", + "$ref": "#/components/schemas/Keccak" + }, + "status": { + "title": "ReceiptStatus", + "description": "Whether or not the transaction threw an error.", + "type": "boolean" + } + } + }, + "BloomFilter": { + "title": "bloomFilter", + "type": "string", + "description": "A 2048 bit bloom filter from the logs of the transaction. Each log sets 3 bits though taking the low-order 11 bits of each of the first three pairs of bytes in a Keccak 256 hash of the log's byte series" + }, + "Log": { + "title": "log", + "type": "object", + "description": "An indexed event generated during a transaction", + "properties": { + "address": { + "title": "LogAddress", + "description": "Sender of the transaction", + "$ref": "#/components/schemas/Address" + }, + "blockHash": { + "$ref": "#/components/schemas/BlockHash" + }, + "blockNumber": { + "$ref": "#/components/schemas/BlockNumber" + }, + "data": { + "title": "LogData", + "description": "The data/input string sent along with the transaction", + "$ref": "#/components/schemas/Bytes" + }, + "logIndex": { + "title": "LogIndex", + "description": "The index of the event within its transaction, null when its pending", + "$ref": "#/components/schemas/Integer" + }, + "removed": { + "title": "logIsRemoved", + "description": "Whether or not the log was orphaned off the main chain", + "type": "boolean" + }, + "topics": { + "$ref": "#/components/schemas/Topics" + }, + "transactionHash": { + "$ref": "#/components/schemas/TransactionHash" + }, + "transactionIndex": { + "$ref": "#/components/schemas/TransactionIndex" + } + } + }, + "Topics": { + "title": "LogTopics", + "description": "Topics are order-dependent. Each topic can also be an array of DATA with 'or' options.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Topic" + } + }, + "Topic": { + "title": "topic", + "description": "32 Bytes DATA of indexed log arguments. (In solidity: The first topic is the hash of the signature of the event (e.g. Deposit(address,bytes32,uint256))", + "$ref": "#/components/schemas/DataWord" + }, + "TransactionIndex": { + "title": "transactionIndex", + "description": "The index of the transaction. null when its pending", + "$ref": "#/components/schemas/IntegerOrNull" + }, + "BlockNumberOrNull": { + "title": "blockNumberOrNull", + "description": "The block number or null when its the pending block", + "oneOf": [ + { + "$ref": "#/components/schemas/BlockNumber" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "BlockHashOrNull": { + "title": "blockHashOrNull", + "description": "The block hash or null when its the pending block", + "$ref": "#/components/schemas/KeccakOrPending" + }, + "NonceOrNull": { + "title": "nonceOrNull", + "description": "Randomly selected number to satisfy the proof-of-work or null when its the pending block", + "oneOf": [ + { + "$ref": "#/components/schemas/Nonce" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "From": { + "title": "From", + "description": "The sender of the transaction", + "$ref": "#/components/schemas/Address" + }, + "To": { + "title": "To", + "description": "Destination address of the transaction. Null if it was a contract create.", + "oneOf": [ + { + "$ref": "#/components/schemas/Address" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "Block": { + "title": "Block", + "description": "The Block is the collection of relevant pieces of information (known as the block header), together with information corresponding to the comprised transactions, and a set of other block headers that are known to have a parent equal to the present block’s parent’s parent.", + "type": "object", + "properties": { + "number": { + "$ref": "#/components/schemas/BlockNumberOrNull" + }, + "hash": { + "$ref": "#/components/schemas/BlockHashOrNull" + }, + "parentHash": { + "$ref": "#/components/schemas/BlockHash" + }, + "nonce": { + "$ref": "#/components/schemas/NonceOrNull" + }, + "sha3Uncles": { + "title": "blockShaUncles", + "description": "Keccak hash of the uncles data in the block", + "$ref": "#/components/schemas/Keccak" + }, + "logsBloom": { + "title": "blockLogsBloom", + "type": "string", + "description": "The bloom filter for the logs of the block or null when its the pending block", + "pattern": "^0x[a-fA-F\\d]+$" + }, + "transactionsRoot": { + "title": "blockTransactionsRoot", + "description": "The root of the transactions trie of the block.", + "$ref": "#/components/schemas/Keccak" + }, + "stateRoot": { + "title": "blockStateRoot", + "description": "The root of the final state trie of the block", + "$ref": "#/components/schemas/Keccak" + }, + "receiptsRoot": { + "title": "blockReceiptsRoot", + "description": "The root of the receipts trie of the block", + "$ref": "#/components/schemas/Keccak" + }, + "miner": { + "$ref": "#/components/schemas/AddressOrNull" + }, + "difficulty": { + "title": "blockDifficulty", + "type": "string", + "description": "Integer of the difficulty for this block" + }, + "totalDifficulty": { + "title": "blockTotalDifficulty", + "description": "Integer of the total difficulty of the chain until this block", + "$ref": "#/components/schemas/IntegerOrNull" + }, + "extraData": { + "title": "blockExtraData", + "type": "string", + "description": "The 'extra data' field of this block" + }, + "size": { + "title": "blockSize", + "type": "string", + "description": "Integer the size of this block in bytes" + }, + "gasLimit": { + "title": "blockGasLimit", + "type": "string", + "description": "The maximum gas allowed in this block" + }, + "gasUsed": { + "title": "blockGasUsed", + "type": "string", + "description": "The total used gas by all transactions in this block" + }, + "timestamp": { + "title": "blockTimeStamp", + "type": "string", + "description": "The unix timestamp for when the block was collated" + }, + "transactions": { + "title": "transactionsOrHashes", + "description": "Array of transaction objects, or 32 Bytes transaction hashes depending on the last given parameter", + "type": "array", + "items": { + "title": "transactionOrTransactionHash", + "oneOf": [ + { + "$ref": "#/components/schemas/Transaction" + }, + { + "$ref": "#/components/schemas/TransactionHash" + } + ] + } + }, + "uncles": { + "title": "uncleHashes", + "description": "Array of uncle hashes", + "type": "array", + "items": { + "title": "uncleHash", + "description": "Block hash of the RLP encoding of an uncle block", + "$ref": "#/components/schemas/Keccak" + } + } + } + }, + "Transaction": { + "title": "transaction", + "type": "object", + "required": [ + "gas", + "gasPrice", + "nonce" + ], + "properties": { + "blockHash": { + "$ref": "#/components/schemas/BlockHashOrNull" + }, + "blockNumber": { + "$ref": "#/components/schemas/BlockNumberOrNull" + }, + "from": { + "$ref": "#/components/schemas/From" + }, + "gas": { + "title": "transactionGas", + "type": "string", + "description": "The gas limit provided by the sender in Wei" + }, + "gasPrice": { + "title": "transactionGasPrice", + "type": "string", + "description": "The gas price willing to be paid by the sender in Wei" + }, + "hash": { + "$ref": "#/components/schemas/TransactionHash" + }, + "input": { + "title": "transactionInput", + "type": "string", + "description": "The data field sent with the transaction" + }, + "nonce": { + "title": "transactionNonce", + "description": "The total number of prior transactions made by the sender", + "$ref": "#/components/schemas/Nonce" + }, + "to": { + "$ref": "#/components/schemas/To" + }, + "transactionIndex": { + "$ref": "#/components/schemas/TransactionIndex" + }, + "value": { + "title": "transactionValue", + "description": "Value of Ether being transferred in Wei", + "$ref": "#/components/schemas/Keccak" + }, + "v": { + "title": "transactionSigV", + "type": "string", + "description": "ECDSA recovery id" + }, + "r": { + "title": "transactionSigR", + "type": "string", + "description": "ECDSA signature r" + }, + "s": { + "title": "transactionSigS", + "type": "string", + "description": "ECDSA signature s" + } + } + }, + "Transactions": { + "title": "transactions", + "description": "An array of transactions", + "type": "array", + "items": { + "$ref": "#/components/schemas/Transaction" + } + }, + "TransactionHash": { + "title": "transactionHash", + "type": "string", + "description": "Keccak 256 Hash of the RLP encoding of a transaction", + "$ref": "#/components/schemas/Keccak" + }, + "KeccakOrPending": { + "title": "keccakOrPending", + "oneOf": [ + { + "$ref": "#/components/schemas/Keccak" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + }, + "Keccak": { + "title": "keccak", + "type": "string", + "description": "Hex representation of a Keccak 256 hash", + "pattern": "^0x[a-fA-F\\d]{64}$" + }, + "Nonce": { + "title": "nonce", + "description": "A number only to be used once", + "$ref": "#/components/schemas/Integer" + }, + "Null": { + "title": "null", + "type": "null", + "description": "Null" + }, + "Integer": { + "title": "integer", + "type": "string", + "pattern": "^0x[a-fA-F0-9]+$", + "description": "Hex representation of the integer" + }, + "Address": { + "title": "address", + "type": "string", + "pattern": "^0x[a-fA-F\\d]{40}$" + }, + "Addresses": { + "title": "addresses", + "type": "array", + "description": "List of contract addresses from which to monitor events", + "items": { + "$ref": "#/components/schemas/Address" + } + }, + "Position": { + "title": "position", + "type": "string", + "description": "Hex representation of the storage slot where the variable exists", + "pattern": "^0x([a-fA-F0-9]?)+$" + }, + "DataWord": { + "title": "dataWord", + "type": "string", + "description": "Hex representation of a 256 bit unit of data", + "pattern": "^0x([a-fA-F\\d]{64})?$" + }, + "Bytes": { + "title": "bytes", + "type": "string", + "description": "Hex representation of a variable length byte array", + "pattern": "^0x([a-fA-F0-9]?)+$" + } + }, + "contentDescriptors": { + "Block": { + "name": "block", + "summary": "A block", + "description": "A block object", + "schema": { + "$ref": "#/components/schemas/Block" + } + }, + "Null": { + "name": "Null", + "description": "JSON Null value", + "summary": "Null value", + "schema": { + "$ref": "#/components/schemas/Null" + } + }, + "Signature": { + "name": "signature", + "summary": "The signature.", + "required": true, + "schema": { + "title": "signatureBytes", + "type": "string", + "description": "Hex representation of byte array between 2 and 65 chars long", + "pattern": "0x^([A-Fa-f0-9]{2}){65}$" + } + }, + "GasPrice": { + "name": "gasPrice", + "required": true, + "schema": { + "title": "gasPriceResult", + "description": "Integer of the current gas price", + "$ref": "#/components/schemas/Integer" + } + }, + "Transaction": { + "required": true, + "name": "transaction", + "schema": { + "$ref": "#/components/schemas/Transaction" + } + }, + "TransactionResult": { + "name": "transactionResult", + "description": "Returns a transaction or null", + "schema": { + "title": "TransactionOrNull", + "oneOf": [ + { + "$ref": "#/components/schemas/Transaction" + }, + { + "$ref": "#/components/schemas/Null" + } + ] + } + }, + "UncleCountResult": { + "name": "uncleCountResult", + "description": "The Number of total uncles in the given block", + "schema": { + "$ref": "#/components/schemas/IntegerOrNull" + } + }, + "Message": { + "name": "message", + "required": true, + "schema": { + "$ref": "#/components/schemas/Bytes" + } + }, + "Filter": { + "name": "filter", + "required": true, + "schema": { + "title": "filter", + "type": "object", + "description": "A filter used to monitor the blockchain for log/events", + "properties": { + "fromBlock": { + "$ref": "#/components/schemas/BlockNumber" + }, + "toBlock": { + "$ref": "#/components/schemas/BlockNumber" + }, + "address": { + "title": "oneOrArrayOfAddresses", + "oneOf": [ + { + "$ref": "#/components/schemas/Address" + }, + { + "$ref": "#/components/schemas/Addresses" + } + ] + }, + "topics": { + "$ref": "#/components/schemas/Topics" + } + } + } + }, + "Address": { + "name": "address", + "required": true, + "schema": { + "$ref": "#/components/schemas/Address" + } + }, + "BlockHash": { + "name": "blockHash", + "required": true, + "schema": { + "$ref": "#/components/schemas/BlockHash" + } + }, + "Nonce": { + "name": "nonce", + "required": true, + "schema": { + "$ref": "#/components/schemas/Nonce" + } + }, + "Position": { + "name": "key", + "required": true, + "schema": { + "$ref": "#/components/schemas/Position" + } + }, + "Logs": { + "name": "logs", + "description": "An array of all logs matching filter with given id.", + "schema": { + "title": "setOfLogs", + "type": "array", + "items": { + "$ref": "#/components/schemas/Log" + } + } + }, + "FilterId": { + "name": "filterId", + "schema": { + "$ref": "#/components/schemas/FilterId" + } + }, + "BlockNumber": { + "name": "blockNumber", + "required": true, + "schema": { + "title": "blockNumberOrTag", + "oneOf": [ + { + "$ref": "#/components/schemas/BlockNumber" + }, + { + "$ref": "#/components/schemas/BlockNumberTag" + } + ] + } + }, + "TransactionHash": { + "name": "transactionHash", + "required": true, + "schema": { + "$ref": "#/components/schemas/TransactionHash" + } + } + } + } + } \ No newline at end of file diff --git a/packages/parsers/src/openrpc/utils/resolveExample.ts b/packages/parsers/src/openrpc/utils/resolveExample.ts new file mode 100644 index 0000000000..09ea316566 --- /dev/null +++ b/packages/parsers/src/openrpc/utils/resolveExample.ts @@ -0,0 +1,21 @@ +import { + ExampleObject, + OpenrpcDocument, + ReferenceObject, +} from "@open-rpc/meta-schema"; +import { isReferenceObject } from "./isReferenceObject"; +import { resolveReference } from "./resolveReference"; + +export function resolveExample( + example: ExampleObject | ReferenceObject | undefined, + document: OpenrpcDocument +): ExampleObject | undefined { + if (isReferenceObject(example)) { + return resolveReference( + example, + document, + undefined + ); + } + return example; +} diff --git a/packages/parsers/src/openrpc/utils/resolveExamplePairing.ts b/packages/parsers/src/openrpc/utils/resolveExamplePairing.ts new file mode 100644 index 0000000000..d248fd2bbd --- /dev/null +++ b/packages/parsers/src/openrpc/utils/resolveExamplePairing.ts @@ -0,0 +1,21 @@ +import { + ExamplePairingObject, + OpenrpcDocument, + ReferenceObject, +} from "@open-rpc/meta-schema"; +import { isReferenceObject } from "./isReferenceObject"; +import { resolveReference } from "./resolveReference"; + +export function resolveExamplePairingOrReference( + examplePairing: ExamplePairingObject | ReferenceObject | undefined, + document: OpenrpcDocument +): ExamplePairingObject | undefined { + if (isReferenceObject(examplePairing)) { + return resolveReference( + examplePairing, + document, + undefined + ); + } + return examplePairing; +}