# API Method

<figure><img src="https://4038204926-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2Fi2DMEZmmK1I0XeD5wJot%2Fuploads%2Fu9XRTqaLMkMNEqHuKid9%2Fdocumentation%20(4).png?alt=media&#x26;token=7178e22b-9886-4bf0-8dd0-ed80b7855e65" alt=""><figcaption></figcaption></figure>

## `ADMIN` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin-methods" id="admin-methods"></a>

#### `admin_addPeer`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_addpeer" id="admin_addpeer"></a>

If connections are timing out, ensure the node ID in the **enode URL** is correct.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`enode`: - String = enode://1fd6bfa1ac606ab3cdbbbacef1b27a1e38b0ac54d5c1a361d07a27211b54b4817aa9b14e596f23c7020d246998f5224ae18882b181dad2ee940d774a085eb7bd\@206.81.20.253:30303

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - `true` if peer added or `false` if peer already a static node

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_addPeer","params":["
enode://1fd6bfa1ac606ab3cdbbbacef1b27a1e38b0ac54d5c1a361d07a27211b54b4817aa9b14e596f23c7020d246998f5224ae18882b181dad2ee940d774a085eb7bd@206.81.20.253:30303
"],"id":1}' https://connect.bit-rock.io
```

#### `admin_changeLogLevel`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_changeloglevel" id="admin_changeloglevel"></a>

Changes the log level without restarting Besu. You can change the log level for all logs, or you can change the log level for specific packages or classes.

You can specify only one log level per RPC call.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `level`: *string* - log level
* `log_filter`: *array* - (optional) packages or classes for which to change the log level

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - `Success` if the log level has changed, otherwise `error`

The following example changes the debug level for specified classes to `DEBUG`.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0", "method":"admin_changeLogLevel", "params":["DEBUG", ["org.hyperledger.besu.ethereum.eth.manager","org.hyperledger.besu.ethereum.p2p.rlpx.connections.netty.ApiHandler"]], "id":1}' https://connect.bit-rock.io
```

The following example changes the debug level of all logs to `WARN`.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_changeLogLevel","params":["WARN"], "id":1}' https://connect.bit-rock.io
```

#### `admin_generateLogBloomCache`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_generatelogbloomcache" id="admin_generatelogbloomcache"></a>

Generates cached log bloom indexes for blocks. APIs such as `eth_getLogs` and `eth_getFilterLogs` use the cache for improved performance.

Note

Each index file contains 100000 blocks. The last fragment of blocks less than 100000 are not indexed.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `startBlock`: *string* - block to start generating indexes
* `endBlock`: *string* - block to stop generating indexes

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - log bloom index details:

* `startBlock`: *string* - starting block for the last requested cache generation
* `endBlock`: *string* - ending block for the last requested cache generation
* `currentBlock`: *string* - most recent block added to the cache
* `indexing`: *boolean* - indicates if indexing is in progress
* *boolean* - indicates acceptance of the request from this call to generate the cache
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{jsonrpc":"2.0","method":"admin_generateLogBloomCache", "params":["0x0", "0x10000"], "id":1}' https://connect.bit-rock.io
```

#### `admin_logsRemoveCache`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_logsremovecache" id="admin_logsremovecache"></a>

Removes cache files for the specified range of blocks.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `fromBlock`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter
* `toBlock`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

You can skip a parameter by using an empty string, `""`. If you specify:

* No parameters, the call removes cache files for all blocks.
* Only `fromBlock`, the call removes cache files for the specified block.
* Only `toBlock`, the call removes cache files from the genesis block to the specified block.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - `Cache Removed` status or `error`.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_logsRemoveCache","params":["1", "100"], "id":1}' https://connect.bit-rock.io
```

#### `admin_logsRepairCache`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_logsrepaircache" id="admin_logsrepaircache"></a>

Repairs cached logs by fixing all segments starting with the specified block number.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`startBlock`: *string* - decimal index of the starting block to fix; defaults to the head block

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - status of the repair request; `Started` or `Already running`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_logsRepairCache","params":["1200"], "id":1}' https://connect.bit-rock.io
```

#### `admin_nodeInfo`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_nodeinfo" id="admin_nodeinfo"></a>

Returns networking information about the node. The information includes general information about the node and specific information from each running Ethereum sub-protocol (for example, `eth`).

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - node object with the following fields:

* `enode`: *string* - enode URL of the node
* `listenAddr`: *string* - host and port for the node
* `name`: *string* - client name
* `id`: *string* - node public key
* `ports`: *object* - peer discovery and listening ports
* `protocols`: *object* - list of objects containing information for each Ethereum sub-protocol

Note

If the node is running locally, the host of the `enode` and `listenAddr` display as `[::]` in the result. When advertising externally, the external address displayed for the `enode` and `listenAddr` is defined by `--nat-method`.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_nodeInfo","params":[],"id":1}' https://connect.bit-rock.io
```

#### `admin_peers`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_peers" id="admin_peers"></a>

Returns networking information about connected remote nodes.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of objects returned for each remote node, with the following fields.

* `version`: *string* - P2P protocol version
* `name`: *string* - client name
* `caps`: *array* of *strings* - list of Ethereum sub-protocol capabilities
* `network`: *object* - local and remote addresses established at time of bonding with the peer (the remote address might not match the hex value for `port`; it depends on which node initiated the connection.)
* `port`: *string* - port on the remote node on which P2P discovery is listening
* `id`: *string* - node public key (excluding the `0x` prefix, the node public key is the ID in the enode URL `enode://<id ex 0x>@<host>:<port>`.)
* `protocols`: *object* - current state of peer including `difficulty` and `head` (`head` is the hash of the highest known block for the peer.)
* `enode`: *string* - enode URL of the remote node
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_peers","params":[],"id":1}' https://connect.bit-rock.io
```

#### `admin_removePeer`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#admin_removepeer" id="admin_removepeer"></a>

Removes a static node.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`enode`: *string* - enode URL of peer to remove

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - `true` if peer removed or `false` if peer not a static node

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"admin_removePeer","params":["enode://f59c0ab603377b6ec88b89d5bb41b98fc385030ab1e4b03752db6f7dab364559d92c757c13116ae6408d2d33f0138e7812eb8b696b2a22fe3332c4b5127b22a3@127.0.0.1:30304"],"id":1}' https://connect.bit-rock.io
```

### `DEBUG` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug-methods" id="debug-methods"></a>

The `DEBUG` API methods allow you to inspect and debug the network. The `DEBUG` API is a more verbose alternative to the `TRACE` API, and its main purpose is compatibility with tools such as Remix. Where these APIs overlap, we recommend using the `TRACE` API for production use over the `DEBUG` API. Specifically, we recommend `trace_block` over `debug_traceBlock`, and `trace_transaction` over `debug_traceTransaction`.

Note

The `DEBUG` API methods are not enabled by default for JSON-RPC. To enable the `DEBUG` API methods, use the `--rpc-http-api` or `--rpc-ws-api` options.

#### `debug_accountAt`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_accountat" id="debug_accountat"></a>

Returns account information at the specified index of the specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockHashOrNumber`: *string* - block hash or number at which to retrieve account information
* `txIndex`: *number* - transaction index at which to retrieve account information
* `address`: *string* - contract or account address for which to retrieve information

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - account details object with the following fields:

* `code`: *data* - code for the account. Displays `0x0` if the address is an externally owned account.
* `nonce`: *quantity* - number of transactions made by the account before this one
* `balance`: *quantity* - balance of the account in Wei
* `codehash`: *data* - code hash for the account

This example uses an externally owned account address for the `address` parameter.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_accountAt","params":["0xc8df1f061abb4d0c107b2b1a794ade8780b3120e681f723fe55a7be586d95ba6", 0, "0xbcde5374fce5edbc8e2a8697c15331677e6ebf0b"],"id":1}' https://connect.bit-rock.io
```

This example uses a contract address for the `address` parameter.

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_accountAt","params":["0x2b76b3a2fc44c0e21ea183d06c846353279a7acf12abcc6fb9d5e8fb14ae2f8c", 0, "0x0e0d2c8f7794e82164f11798276a188147fbd415"],"id":1}' https://connect.bit-rock.io
```

#### `debug_accountRange`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_accountrange" id="debug_accountrange"></a>

Retesteth uses `debug_accountRange` to implement debugging.

Returns the accounts for a specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockHashOrNumber`: *string* - block hash or number at which to retrieve account information
* `txIndex`: *number* - transaction index at which to retrieve account information
* `address`: *string* - address hash from which to start
* `limit`: *integer* - maximum number of account entries to return

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - account details object with the following fields:

* `addressMap`: *map* of *strings* to *strings* - map of address hashes and account addresses
* `nextKey`: *string* - hash of the next address if any addresses remain in the state, otherwise zero
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_accountRange","params":["12345", 0, "0", 5],"id":1}' http://127.0.0.1:8545
```

#### `debug_batchSendRawTransaction`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_batchsendrawtransaction" id="debug_batchsendrawtransaction"></a>

Sends a list of signed transactions. This is used to quickly load a network with a lot of transactions. This does the same thing as calling `eth_sendRawTransaction` multiple times.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`data`: *string* - signed transaction data array

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - object returned for each transaction, with the following fields:

* `index`: *string* - index of the transaction in the request parameters array
* `success`: *boolean* - indicates whether or not the transaction has been added to the transaction pool
* `errorMessage`: *string* - (optional) error message
* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_batchSendRawTransaction","params":["0xf868808203e882520894627306090abab3a6e1400e9345bc60c78a8bef57872386f26fc10000801ba0ac74ecfa0e9b85785f042c143ead4780931234cc9a032fce99fab1f45e0d90faa02fd17e8eb433d4ca47727653232045d4f81322619c0852d3fe8ddcfcedb66a43","0x416","0xf868018203e882520894627306090abab3a6e1400e9345bc60c78a8bef57872386f26fc10000801ca0b24ea1bee8fe36984c36acbf80979a4509f23fc17141851e08d505c0df158aa0a00472a05903d4cd7a811bd4d5c59cc105d93f5943f3393f253e92e65fc36e7ce0","0xf868808203e882520894627306090abab3a6e1400e9345bc60c78a8bef5787470de4df820000801ca0f7936b4de04792e3c65095cfbfd1399d231368f5f05f877588c0c8509f6c98c9a01834004dead527c8da1396eede42e1c60e41f38a77c2fd13a6e495479c729b99"],"id":1}' https://connect.bit-rock.io
```

#### `debug_getBadBlocks`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_getbadblocks" id="debug_getbadblocks"></a>

Returns a list of invalid blocks. This is used to detect and analyze consensus flaws.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of block objects

* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_getBadBlocks","params":[],"id":1}' https://connect.bit-rock.io
```

#### `debug_getRawBlock`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_getrawblock" id="debug_getrawblock"></a>

Returns the RLP encoding of the specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - RLP-encoded block object

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_getRawBlock","params":["0x32026E"],"id":1}' https://connect.bit-rock.io
```

Returns the RLP encoding of the header of specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - RLP-encoded block header or `error`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_getRawHeader","params":["0x32026E"],"id":1}' https://connect.bit-rock.io
```

#### `debug_metrics`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_metrics" id="debug_metrics"></a>

Returns metrics providing information on the internal operation of Besu.

The available metrics might change over time. The JVM metrics might vary based on the JVM implementation used.

The metric types are:

* Timer
* Counter
* Gauge

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - metrics object

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_metrics","params":[],"id":1}' https://connect.bit-rock.io
```

#### `debug_replayBlock`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_replayblock" id="debug_replayblock"></a>

Re-imports the block matching the specified block number, by rolling the head of the local chain back to the block right before the specified block, then importing the specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - `Success` or `error`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_replayBlock","params":["0x1"],"id":1}' https://connect.bit-rock.io
```

#### `debug_resyncWorldstate`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_resyncworldstate" id="debug_resyncworldstate"></a>

Triggers a re-synchronization of the world state while retaining imported blocks. This is useful if there are world state database inconsistencies (for example, Bonsai database issues).

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - `Success` or `error`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_resyncWorldstate","params":[],"id":1}' https://connect.bit-rock.io
```

#### `debug_setHead`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_sethead" id="debug_sethead"></a>

Sets the current head of the local chain to the block matching the specified block number.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - `Success` or `error`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_setHead","params":["0x1"],"id":1}' https://connect.bit-rock.io
```

#### `debug_standardTraceBlockToFile`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_standardtraceblocktofile" id="debug_standardtraceblocktofile"></a>

Generates files containing the block trace. A separate file is generated for each transaction in the block.

You can also specify a trace file for a specific transaction in a block.

Use `debug_standardTraceBadBlockToFile` to view the trace for an invalid block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockHash`: *string* - block hash

`txHash`: *string* - (optional) transaction hash; if omitted, a trace file is generated for each transaction in the block.

`disableMemory`: *boolean* - (optional) specifies whether to capture EVM memory during the trace; defaults to `true`

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - location of the generated trace files

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_standardTraceBlockToFile","params":["0x2dc0b6c43144e314a86777b4bd4f987c0790a6a0b21560671d221ed81a23f2dc", {
"txHash": "0x4ff04c4aec9517721179c8dd435f47fbbfc2ed26cd4926845ab687420d5580a6", "disableMemory": false}], "id":1}' https://connect.bit-rock.io
```

#### `debug_standardTraceBadBlockToFile`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_standardtracebadblocktofile" id="debug_standardtracebadblocktofile"></a>

Generates files containing the block trace of invalid blocks. A separate file is generated for each transaction in the block.

Use `debug_standardTraceBlockToFile` to view the trace for a valid block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockHash`: *string* - block hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - location of the generated trace files

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_standardTraceBadBlockToFile","params":["0x53741e9e94791466d117c5f9e41a2ed1de3f73d39920c621dfc2f294e7779baa"], "id":1}' https://connect.bit-rock.io
```

#### `debug_storageRangeAt`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_storagerangeat" id="debug_storagerangeat"></a>

Remix uses `debug_storageRangeAt` to implement debugging. Use the *Debugger* tab in Remix instead of calling `debug_storageRangeAt` directly.

Returns the contract storage for the specified range.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockHash`: *string* - block hash
* `txIndex`: *number* - transaction index from which to start
* `address`: *string* - contract address
* `startKey`: *string* - start key
* `limit`: *number* - number of storage entries to return

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - range object.

* curl HTTP request
* wscat WS request
* JSON result
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_storageRangeAt","params":["0x2b76b3a2fc44c0e21ea183d06c846353279a7acf12abcc6fb9d5e8fb14ae2f8c",0,"0x0e0d2c8f7794e82164f11798276a188147fbd415","0x0000000000000000000000000000000000000000000000000000000000000000",1], "id":1}' https://connect.bit-rock.io
```

#### `debug_traceBlock`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_traceblock" id="debug_traceblock"></a>

Returns full trace of all invoked opcodes of all transactions included in the block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `block`: *string* - RLP of the block
* `options`: *object* - request options object with the following fields (all optional and default to `false`):
  * `disableStorage`: *boolean* - `true` disables storage capture.
  * `disableMemory`: *boolean* - `true` disables memory capture.
  * `disableStack` : *boolean* - `true` disables stack capture.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - trace object

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_traceBlock","params":["0xf90277f90208a05a41d0e66b4120775176c09fcf39e7c0520517a13d2b57b18d33d342df038bfca01dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d4934794e6a7a1d47ff21b6321162aea7c6cb457d5476bcaa00e0df2706b0a4fb8bd08c9246d472abbe850af446405d9eba1db41db18b4a169a04513310fcb9f6f616972a3b948dc5d547f280849a87ebb5af0191f98b87be598a0fe2bf2a941abf41d72637e5b91750332a30283efd40c424dc522b77e6f0ed8c4b9010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000860153886c1bbd82b44382520b8252088455c426598b657468706f6f6c2e6f7267a0b48c515a9dde8d346c3337ea520aa995a4738bb595495506125449c1149d6cf488ba4f8ecd18aab215f869f86780862d79883d2000825208945df9b87991262f6ba471f09758cde1c0fc1de734827a69801ca088ff6cf0fefd94db46111149ae4bfc179e9b94721fffd821d38d16464b3f71d0a045e0aff800961cfce805daef7016b9b675c137a6a41a548f7b60a3484c06a33ac0"],"id":1}' https://connect.bit-rock.io
```

#### `debug_traceBlockByHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_traceblockbyhash" id="debug_traceblockbyhash"></a>

Returns full trace of all invoked opcodes of all transactions included in the block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockHash`: *string* - block hash
* `options`: *object* - request options object with the following fields (all optional and default to `false`):
  * `disableStorage`: *boolean* - `true` disables storage capture.
  * `disableMemory`: *boolean* - `true` disables memory capture.
  * `disableStack` : *boolean* - `true` disables stack capture.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of trace objects

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_traceBlockByHash","params":["0xaceb3b2c9b25b0589230873921eb894b28722011b8df63977145517d754875a5"], "id":1}' https://connect.bit-rock.io
```

#### `debug_traceBlockByNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#debug_traceblockbynumber" id="debug_traceblockbynumber"></a>

Returns full trace of all invoked opcodes of all transactions included in the block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter
* `options`: *object* - request options object with the following fields (all optional and default to `false`):
  * `disableStorage`: *boolean* - `true` disables storage capture.
  * `disableMemory`: *boolean* - `true` disables memory capture.
  * `disableStack` : *boolean* - `true` disables stack capture.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of trace objects

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"debug_traceBlockByNumber","params":["0x7224",{"disableStorage":true}], "id":1}' http://127.0.0.1:8545
```

### `ETH` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth-methods" id="eth-methods"></a>

The `ETH` API methods allow you to interact with the blockchain.

Note

Methods with an equivalent GraphQL query include a GraphQL request and result in the method example. The parameter and result descriptions apply to the JSON-RPC requests. The GraphQL specification is defined in the schema.

#### `eth_accounts`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_accounts" id="eth_accounts"></a>

Returns a list of account addresses a client owns.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *strings* - list of 20-byte account addresses owned by the client

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_blockNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_blocknumber" id="eth_blocknumber"></a>

Returns the index corresponding to the block number of the current chain head.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - hexadecimal integer representing the index corresponding to the block number of the current chain head

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":51}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_call`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_call" id="eth_call"></a>

Invokes a contract function locally and does not change the state of the blockchain.

You can interact with contracts using `eth_sendRawTransaction` or `eth_call`.

If revert reason is enabled with `--revert-reason-enabled`, the `eth_call` error response includes the revert reason.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`call`: *object* - transaction call object

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

Note

By default, `eth_call` does not fail if the sender account has an insufficient balance. This is done by setting the balance of the account to a large amount of ether. To enforce balance rules, set the `strict` parameter in the transaction call object to `true`.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - return value of the executed contract

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_call","params":[{"to":"0x69498dd54bd25aa0c886cf1f8b8ae0856d55ff13","value":"0x1"}, "latest"],"id":53}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

Example of a simulated contract creation

The following example creates a simulated contract by not including the `to` parameter from the transaction call object in the `call` parameter. Besu simulates the data to create the contract.

* curl HTTP
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_call","params":[{"from":"0xfe3b557e8fb62b89f4916b721be55ceb828dbd73", "data":"0x6080604052336000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555034801561005057600080fd5b5061021e806100606000396000f3fe608060405234801561001057600080fd5b50600436106100415760003560e01c8063445df0ac146100465780638da5cb5b14610064578063fdacd576146100ae575b600080fd5b61004e6100dc565b6040518082815260200191505060405180910390f35b61006c6100e2565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6100da600480360360208110156100c457600080fd5b8101908080359060200190929190505050610107565b005b60015481565b6000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16146101ac576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260338152602001806101b76033913960400191505060405180910390fd5b806001819055505056fe546869732066756e6374696f6e206973207265737472696374656420746f2074686520636f6e74726163742773206f776e6572a265627a7a7231582007302f208a10686769509b529e1878bda1859883778d70dedd1844fe790c9bde64736f6c63430005100032","gas":"0x439cf","gasPrice":"0x0"},"latest"],"id":53}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_chainId`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_chainid" id="eth_chainid"></a>

Returns the chain ID.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - chain ID in hexadecimal

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_chainId","params":[],"id":51}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_coinbase`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_coinbase" id="eth_coinbase"></a>

Returns the client coinbase address. The coinbase address is the account to pay mining rewards to.

To set a coinbase address, start Besu with the `--miner-coinbase` option set to a valid Ethereum account address. You can get the Ethereum account address from a client such as MetaMask or Bitrock Scan. For example:

Example

```
besu --miner-coinbase="0xfe3b557e8fb62b89f4916b721be55ceb828dbd73" --rpc-http-enabled
```

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - coinbase address

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_coinbase","params":[],"id":53}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_createAccessList`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_createaccesslist" id="eth_createaccesslist"></a>

Creates an EIP-2930 access list that you can include in a transaction.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`transaction`: *object* - transaction call object

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - access list object with the following fields:

* `accessList`: *array* of *objects* - list of objects with the following fields:
  * `address`: *string* - addresses to be accessed by the transaction
  * `storageKeys`: *array* - storage keys to be accessed by the transaction
* `gasUsed`: *string* - approximate gas cost for the transaction if the access list is included
* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"method":"eth_createAccessList","params":[{"from": "0xaeA8F8f781326bfE6A7683C2BD48Dd6AA4d3Ba63", "data": "0x608060806080608155"}, "pending"],"id":1,"jsonrpc":"2.0"}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_estimateGas`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_estimategas" id="eth_estimategas"></a>

Returns an estimate of the gas required for a transaction to complete. The estimation process does not use gas and the transaction is not added to the blockchain. The resulting estimate can be greater than the amount of gas the transaction ends up using, for reasons including EVM mechanics and node performance.

The `eth_estimateGas` call does not send a transaction. You must call `eth_sendRawTransaction` to execute the transaction.

If revert reason is enabled with `--revert-reason-enabled`, the `eth_estimateGas` error response includes the revert reason.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

For `eth_estimateGas`, all fields are optional because setting a gas limit is irrelevant to the estimation process (unlike transactions, in which gas limits apply).

`call`: *object* - transaction call object

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - amount of gas used

The following example returns an estimate of 21000 wei (`0x5208`) for the transaction.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_estimateGas","params":[{"from":"0xFE3B557E8Fb62b89F4916B721be55cEb828dBd73","to":"0x44Aa93095D6749A706051658B970b941c72c1D53","value":"0x1"}],"id":53}' curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":53}' https://connect.bit-rock.io
```

The following example request estimates the cost of deploying a simple storage smart contract to the network. The data field contains the hash of the compiled contract you want to deploy. (You can get the compiled contract hash from your IDE, for example, **Remix > Compile tab > details > WEB3DEPLOY**.) The result is 113355 wei.

* curl HTTP request
* JSON result

```
curl -X POST \
https://connect.bit-rock.io \
-H 'Content-Type: application/json' \
-d '{
  "jsonrpc": "2.0",
  "method": "eth_estimateGas",
  "params": [{
    "from": "0x8bad598904ec5d93d07e204a366d084a80c7694e",
    "data": "0x608060405234801561001057600080fd5b5060e38061001f6000396000f3fe6080604052600436106043576000357c0100000000000000000000000000000000000000000000000000000000900480633fa4f24514604857806355241077146070575b600080fd5b348015605357600080fd5b50605a60a7565b6040518082815260200191505060405180910390f35b348015607b57600080fd5b5060a560048036036020811015609057600080fd5b810190808035906020019092919050505060ad565b005b60005481565b806000819055505056fea165627a7a7230582020d7ad478b98b85ca751c924ef66bcebbbd8072b93031073ef35270a4c42f0080029"
  }],
  "id": 1
}'
```

#### `eth_feeHistory`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_feehistory" id="eth_feehistory"></a>

Returns base fee per gas and transaction effective priority fee per gas history for the requested block range, allowing you to track trends over time.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockCount`: *integer* or *string* - Number of blocks in the requested range. Between 1 and 1024 blocks can be requested in a single query. If blocks in the specified block range are not available, then only the fee history for available blocks is returned. Accepts hexadecimal or integer values.
* `newestBlock`: *string* - Integer representing the highest number block of the requested range or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter.
* `array` of `integers` - (optional) A monotonically increasing list of percentile values to sample from each block's effective priority fees per gas in ascending order, weighted by gas used.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - Fee history results object.

* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_feeHistory","params": ["0x5", "latest", [20,30]],"id":1}' https://connect.bit-rock.io
```

#### `eth_gasPrice`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gasprice" id="eth_gasprice"></a>

Returns a percentile gas unit price for the most recent blocks, in Wei. By default, the last 100 blocks are examined and the 50th percentile gas unit price (that is, the median value) is returned.

If there are no blocks, the value for `--min-gas-price` is returned. The value returned is restricted to values between `--min-gas-price` and `--api-gas-price-max`. By default, 1000 Wei and 500GWei.

Use the `--api-gas-price-blocks`, `--api-gas-price-percentile` , and `--api-gas-price-max` command line options to configure the `eth_gasPrice` default values.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - percentile gas unit price for the most recent blocks, in Wei, as a hexadecimal value

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_gasPrice","params":[],"id":53}' https://connect.bit-rock.io
```

#### `eth_getBalance`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getbalance" id="eth_getbalance"></a>

Returns the account balance of the specified address.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `address`: *string* - 20-byte account address from which to retrieve the balance
* `blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - current balance, in Wei, as a hexadecimal value

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBalance","params":["0xfe3b557e8fb62b89f4916b721be55ceb828dbd73", "latest"],"id":53}' https://connect.bit-rock.io
```

#### `eth_getBlockByHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getblockbyhash" id="eth_getblockbyhash"></a>

Returns information about the block matching the specified block hash.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `hash`: *string* - 32-byte hash of a block
* `verbose`: *boolean* - if `true`, returns the full transaction objects; if `false`, returns the transaction hashes

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - block object, or `null` when there is no block

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockByHash","params":["0xd5f1812548be429cbdc6376b29611fc49e06f1359758c4ceaaa3b393e2239f9c", false],"id":53}' https://connect.bit-rock.io
```

#### `eth_getBlockByNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getblockbynumber" id="eth_getblockbynumber"></a>

Returns information about the block matching the specified block number.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, `pending`, `finalized`, or `safe` as described in block parameter
* `verbose`: *boolean* - if `true`, returns the full transaction objects; if `false`, returns only the hashes of the transactions.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - block object, or `null` when there is no block.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockByNumber","params":["0x68B3", true],"id":1}' https://connect.bit-rock.io
```

#### `eth_getBlockTransactionCountByHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getblocktransactioncountbyhash" id="eth_getblocktransactioncountbyhash"></a>

Returns the number of transactions in the block matching the specified block hash.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`hash`: *string* - 32-byte block hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *number* - integer representing the number of transactions in the specified block, or `null` if no matching block hash is found

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockTransactionCountByHash","params":["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"],"id":53}' https://connect.bit-rock.io
```

#### `eth_getBlockTransactionCountByNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getblocktransactioncountbynumber" id="eth_getblocktransactioncountbynumber"></a>

Returns the number of transactions in a block matching the specified block number.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - integer representing the number of transactions in the specified block, or `null` if no matching block number is found

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockTransactionCountByNumber","params":["0xe8"],"id":51}' https://connect.bit-rock.io
```

#### `eth_getCode`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getcode" id="eth_getcode"></a>

Returns the code of the smart contract at the specified address. Besu stores compiled smart contract code as a hexadecimal value.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`address`: *string* - 20-byte contract address

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *data* - code stored at the specified address

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getCode","params":["0xa50a51c09a5c451c52bb714527e1974b686d8e77", "latest"],"id":53}' https://connect.bit-rock.io
```

#### `eth_getFilterChanges`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getfilterchanges" id="eth_getfilterchanges"></a>

Polls the specified filter and returns an array of changes that have occurred since the last poll.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`filterId`: *string* - filter ID

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *strings* or *objects* - if nothing changed since the last poll, an empty list; otherwise:

* For filters created with `eth_newBlockFilter`, returns block hashes.
* For filters created with `eth_newPendingTransactionFilter`, returns transaction hashes.
* For filters created with `eth_newFilter`, returns log objects.
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getFilterChanges","params":["0xf8bf5598d9e04fbe84523d42640b9b0e"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getFilterLogs`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getfilterlogs" id="eth_getfilterlogs"></a>

Returns an array of logs for the specified filter.

Leave the `--auto-log-bloom-caching-enabled` command line option at the default value of `true` to improve log retrieval performance.

Note

`eth_getFilterLogs` is only used for filters created with `eth_newFilter`. To specify a filter object and get logs without creating a filter, use `eth_getLogs`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`filterId`: *string* - filter ID

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of log objects

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getFilterLogs","params":["0x5ace5de3985749b6a1b2b0d3f3e1fb69"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getLogs`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getlogs" id="eth_getlogs"></a>

Returns an array of logs matching a specified filter object.

Leave the `--auto-log-bloom-caching-enabled` command line option at the default value of `true` to improve log retrieval performance.

caution

Using `eth_getLogs` to get logs from a large range of blocks, especially an entire chain from its genesis block, might cause Besu to hang for an indeterminable amount of time while generating the response. We recommend setting a range limit using the `--rpc-max-logs-range` option (or leaving it at its default value of 1000).

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`filterOptions`: *object* - filter options object

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of log objects

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getLogs","params":[{"fromBlock":"earliest", "toBlock":"latest", "address": "0x2e1f232a9439c3d459fceca0beef13acc8259dd8", "topics":[]}], "id":1}' https://connect.bit-rock.io
```

#### `eth_getMinerDataByBlockHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getminerdatabyblockhash" id="eth_getminerdatabyblockhash"></a>

Returns miner data for the specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`hash`: *string* - 32-byte block hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - miner data object

* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method": "eth_getMinerDataByBlockHash","params": ["0xbf137c3a7a1ebdfac21252765e5d7f40d115c2757e4a4abee929be88c624fdb7"],"id": 1}' https://connect.bit-rock.io
```

#### `eth_getMinerDataByBlockNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getminerdatabyblocknumber" id="eth_getminerdatabyblocknumber"></a>

Returns miner data for the specified block.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - miner data object

* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method": "eth_getMinerDataByBlockNumber","params": ["0x7689D2"],"id": 1}' https://connect.bit-rock.io
```

#### `eth_getProof`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getproof" id="eth_getproof"></a>

Returns the account and storage values of the specified account, including the Merkle proof.

The API allows IoT devices or mobile apps which are unable to run light clients to verify responses from untrusted sources, by using a trusted block hash.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`address`: *string* - 20-byte address of the account or contract

`keys`: *array* of *strings* - list of 32-byte storage keys to generate proofs for

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - account details object with the following fields:

* `balance`: *string* - account balance
* `codeHash`: *string* - 32-byte hash of the account code
* `nonce`: *string* - number of transactions sent from the account
* `storageHash`: *string* - 32-byte SHA3 of the `storageRoot`
* `accountProof`: *array* of *strings* - list of RLP-encoded Merkle tree nodes, starting with the `stateRoot`
* `storageProof`: *array* of *objects* - list of storage entry objects with the following fields:
  * `key`: *string* - storage key
  * `value`: *string* - storage value
  * `proof`: *array* of *strings* - list of RLP-encoded Merkle tree nodes, starting with the `storageHash`
* curl HTTP
* wscat WS
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method": "eth_getProof","params": [
"0a8156e7ee392d885d10eaa86afd0e323afdcd95", ["0x0000000000000000000000000000000000000000000000000000000000000347"], "latest"],"id": 1}' https://connect.bit-rock.io
```

#### `eth_getStorageAt`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getstorageat" id="eth_getstorageat"></a>

Returns the value of a storage position at a specified address.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`address`: *string* - 20-byte storage address

`index`: *string* - integer index of the storage position

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result` : *string* - value at the specified storage position

Calculating the correct position depends on the storage you want to retrieve.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method": "eth_getStorageAt","params": ["0x‭3B3F3E‬","0x0","latest"],"id": 53}' http://127.0.0.1:8545
```

#### `eth_getTransactionByBlockHashAndIndex`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gettransactionbyblockhashandindex" id="eth_gettransactionbyblockhashandindex"></a>

Returns transaction information for the specified block hash and transaction index position.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`block`: *string* - 32-byte hash of a block

`index`: *string* - integer representing the transaction index position

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - transaction object, or `null` when there is no transaction

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByBlockHashAndIndex","params":["0xbf137c3a7a1ebdfac21252765e5d7f40d115c2757e4a4abee929be88c624fdb7", "0x2"], "id":1}' https://connect.bit-rock.io
```

#### `eth_getTransactionByBlockNumberAndIndex`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gettransactionbyblocknumberandindex" id="eth_gettransactionbyblocknumberandindex"></a>

Returns transaction information for the specified block number and transaction index position.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

`index`: *string* - transaction index position

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - transaction object, or `null` when there is no transaction

This request returns the third transaction in the 82990 block on the Bitrock Chain. You can also view this block and transaction on Bitrock Scan.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByBlockNumberAndIndex","params":["82990", "0x2"], "id":1}' https://connect.bit-rock.io
```

#### `eth_getTransactionByHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gettransactionbyhash" id="eth_gettransactionbyhash"></a>

Returns transaction information for the specified transaction hash.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`transaction`: *string* - 32-byte transaction hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - transaction object, or `null` when there is no transaction

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByHash","params":["0xa52be92809541220ee0aaaede6047d9a6c5d0cd96a517c854d944ee70a0ebb44"],"id":53}' https://connect.bit-rock.io
```

#### `eth_getTransactionCount`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gettransactioncount" id="eth_gettransactioncount"></a>

Returns the number of transactions sent from a specified address. Use the `pending` tag to get the next account nonce not used by any pending transactions.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`address`: *string* - 20-byte account address

`blockNumber` or `blockHash`: *string* - integer representing a block number, block hash, or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - integer representing the number of transactions sent from the specified address

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionCount","params":["0xc94770007dda54cF92009BFF0dE90c06F603a09f","latest"],"id":1}' http://127.0.0.1:8545
```

#### `eth_getTransactionReceipt`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_gettransactionreceipt" id="eth_gettransactionreceipt"></a>

Returns the receipt of a transaction by transaction hash. Receipts for pending transactions are not available.

If you enabled revert reason, the receipt includes available revert reasons in the response.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`transaction`: *string* - 32-byte hash of a transaction

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - transaction receipt object, or `null` when there is no receipt

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionReceipt","params":["0x504ce587a65bdbdb6414a0c6c16d86a04dd79bfcc4f2950eec9634b30ce5370f"],"id":53}' https://connect.bit-rock.io
```

#### `eth_getUncleByBlockHashAndIndex`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getunclebyblockhashandindex" id="eth_getunclebyblockhashandindex"></a>

Returns uncle specified by block hash and index.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`block`: *string* - 32-byte block hash

`uncleIndex`: *string* - index of the uncle

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - block object

note

Uncles don't contain individual transactions.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleByBlockHashAndIndex","params":["0xc48fb64230a82f65a08e7280bd8745e7fea87bc7c206309dee32209fe9a985f7", "0x0"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getUncleByBlockNumberAndIndex`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getunclebyblocknumberandindex" id="eth_getunclebyblocknumberandindex"></a>

Returns uncle specified by block number and index.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter
* `uncleIndex`: *string* - index of the uncle

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - block object

note

Uncles do not contain individual transactions.

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleByBlockNumberAndIndex","params":["0x7689D2", "0x0"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getUncleCountByBlockHash`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getunclecountbyblockhash" id="eth_getunclecountbyblockhash"></a>

Returns the number of uncles in a block from a block matching the given block hash.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`block`: *string* - 32-byte block hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - integer representing the number of uncles in the specified block

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleCountByBlockHash","params":["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getUncleCountByBlockNumber`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getunclecountbyblocknumber" id="eth_getunclecountbyblocknumber"></a>

Returns the number of uncles in a block matching the specified block number.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`blockNumber`: *string* - integer representing a block number or one of the string tags `latest`, `earliest`, or `pending`, as described in block parameter

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - integer representing the number of uncles in the specified block

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleCountByBlockNumber","params":["0xe8"],"id":1}' https://connect.bit-rock.io
```

#### `eth_getWork`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_getwork" id="eth_getwork"></a>

Returns the hash of the current block, the seed hash, and the required target boundary condition.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *strings* - array with the following items:

* `header`: *string* - 32-byte hash of the current block header (PoW-hash)
* `seed`: *string* - 32-byte seed hash used for the DAG
* `target`: *string* - 32-byte required target boundary condition: 2^256 / difficulty
* `blockNumber`: *string* - hexadecimal integer representing the current block number
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getWork","params":[],"id":1}' https://connect.bit-rock.io
```

#### `eth_hashrate`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_hashrate" id="eth_hashrate"></a>

Returns the number of hashes per second with which the node is mining.

When the stratum server is enabled, this method returns the cumulative hashrate of all sealers reporting their hashrate.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - number of hashes per second

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_hashrate","params":[],"id":1}' https://connect.bit-rock.io
```

#### `eth_mining`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_mining" id="eth_mining"></a>

Whether the client is actively mining new blocks. Besu pauses mining while the client synchronizes with the network regardless of command settings or methods called.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - indicates if the client is actively mining new blocks

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_mining","params":[],"id":53}' http://127.0.0.1:8545
```

#### `eth_newBlockFilter`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_newblockfilter" id="eth_newblockfilter"></a>

Creates a filter to retrieve new block hashes. To poll for new blocks, use `eth_getFilterChanges`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - filter ID

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newBlockFilter","params":[],"id":1}' https://connect.bit-rock.io
```

#### `eth_newFilter`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_newfilter" id="eth_newfilter"></a>

Creates a log filter. To poll for logs associated with the created filter, use `eth_getFilterChanges`. To get all logs associated with the filter, use `eth_getFilterLogs`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`filterOptions`: *object* - filter options object

note

`fromBlock` and `toBlock` in the filter options object default to `latest`.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - filter ID

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newFilter","params":[{"fromBlock":"earliest", "toBlock":"latest", "topics":[]}],"id":1}' https://connect.bit-rock.io
```

#### `eth_newPendingTransactionFilter`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_newpendingtransactionfilter" id="eth_newpendingtransactionfilter"></a>

Creates a filter to retrieve new pending transactions hashes. To poll for new pending transactions, use `eth_getFilterChanges`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - filter ID

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newPendingTransactionFilter","params":[],"id":1}' https://connect.bit-rock.io
```

#### `eth_protocolVersion`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_protocolversion" id="eth_protocolversion"></a>

Returns current Ethereum protocol version.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - Ethereum protocol version

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_protocolVersion","params":[],"id":1}' https://connect.bit-rock.io
```

#### `eth_sendRawTransaction`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_sendrawtransaction" id="eth_sendrawtransaction"></a>

Sends a signed transaction. A transaction can send ether, deploy a contract, or interact with a contract. Set the maximum transaction fee for transactions using the `--rpc-tx-feecap` CLI option.

You can interact with contracts using `eth_sendRawTransaction` or `eth_call`.

To avoid exposing your private key, create signed transactions offline and send the signed transaction data using `eth_sendRawTransaction`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`transaction`: *string* - signed transaction serialized to hexadecimal format

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - 32-byte transaction hash

* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_sendRawTransaction","params":["0xf869018203e882520894f17f52151ebef6c7334fad080c5704d77216b732881bc16d674ec80000801ba02da1c48b670996dcb1f447ef9ef00b33033c48a4fe938f420bec3e56bfd24071a062e0aa78a81bf0290afbc3a9d8e9a068e6d74caa66c5e0fa8a46deaae96b0833"],"id":1}' https://connect.bit-rock.io
```

#### `eth_submitHashrate`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_submithashrate" id="eth_submithashrate"></a>

Submits the mining hashrate. This is used by mining software such as Ethminer.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `hashrate`: *string* - 32-byte hexadecimal string representation of the hashrate
* `id`: *string* - 32-byte random hexadecimal ID identifying the client

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - indicates if submission is successful

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0", "method":"eth_submitHashrate", "params":["0x0000000000000000000000000000000000000000000000000000000000500000", "0x59daa26581d0acd1fce254fb7e85952f4c09d0915afd33d3886cd914bc7d283c"],"id":1}' https://connect.bit-rock.io
```

#### `eth_submitWork`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_submitwork" id="eth_submitwork"></a>

Submits a proof of work (Ethash) solution. This is used by mining software such as Ethminer.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `nonce`: *string* - retrieved 8-byte nonce
* `header`: *string* - 32-byte hash of the block header (PoW-hash)
* `digest`: *string* - 32-bytes mix digest

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - indicates if the provided solution is valid

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0", "method":"eth_submitWork", "params":["0x0000000000000001", "0x1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdef", "0xD1GE5700000000000000000000000000D1GE5700000000000000000000000000"],"id":1}' https://connect.bit-rock.io
```

#### `eth_syncing`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_syncing" id="eth_syncing"></a>

Returns an object with data about the synchronization status, or `false` if not synchronizing.

note

Once the node reaches the head of the chain, `eth_syncing` returns false, indicating that there is no active syncing target.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* or *boolean* - synchronization status data object with the following fields, or `false` if not synchronizing:

* `startingBlock`: *string* - index of the highest block on the blockchain when the network synchronization starts
* `currentBlock`: *string* - index of the latest block (also known as the best block) for the current node (this is the same index that `eth_blockNumber` returns.)
* `highestBlock`: *string* - index of the highest known block in the peer network (that is, the highest block so far discovered among peer nodes. This is the same value as `currentBlock` if the current node has no peers.)
* `pulledStates`: *string* - if fast synchronizing, the number of state entries fetched so far, or `null` if this is not known or not relevant (if full synchronizing or fully synchronized, this field is not returned.)
* `knownStates`: *string* - if fast synchronizing, the number of states the node knows of so far, or `null` if this is not known or not relevant (if full synchronizing or fully synchronized, this field is not returned.)
* curl HTTP
* wscat WS
* JSON result
* curl GraphQL
* GraphQL
* GraphQL result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_syncing","params":[],"id":51}' https://connect.bit-rock.io
```

#### `eth_uninstallFilter`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#eth_uninstallfilter" id="eth_uninstallfilter"></a>

Uninstalls a filter with the specified ID. When a filter is no longer required, call this method.

Filters time out when not requested by `eth_getFilterChanges` or `eth_getFilterLogs` for 10 minutes.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`filterId`: *string* - filter ID

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - indicates if the filter is successfully uninstalled

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"eth_uninstallFilter","params":["0x70355a0b574b437eaa19fe95adfedc0a"],"id":1}' https://connect.bit-rock.io
```

### `MINER` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miner-methods" id="miner-methods"></a>

The `MINER` API methods allow you to control the node’s mining operation.

note

The `MINER` API methods are not enabled by default for JSON-RPC. To enable the `MINER` API methods, use the `--rpc-http-api` or `--rpc-ws-api` options.

#### `miner_changeTargetGasLimit`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miner_changetargetgaslimit" id="miner_changetargetgaslimit"></a>

Updates the target gas limit set using the `--target-gas-limit` command line option.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`gasPrice`: *number* - target gas price in Wei

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - `Success` or `error`

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"miner_changeTargetGasLimit","params":[800000], "id":1}' https://connect.bit-rock.io
```

#### `miner_setCoinbase`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miner_setcoinbase" id="miner_setcoinbase"></a>

Sets the Coinbase, the address for the mining rewards.

note

You can also use `miner_setEtherbase` as an alternative method. They both work the same way. Etherbase is a historic name for Coinbase.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`coinbase`: *string* - Account address you pay mining rewards to

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - `true` when address is set

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"miner_setCoinbase","params":["0xFE3B557E8Fb62b89F4916B721be55cEb828dBd73"],"id":1}' https://connect.bit-rock.io
```

#### `miner_start`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miner_start" id="miner_start"></a>

Starts the mining process. To start mining, you must first specify a miner coinbase using the `--miner-coinbase` command line option or using `miner_setCoinbase`.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - `true` if mining starts, or if the node is already mining

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"miner_start","params":[],"id":1}' https://connect.bit-rock.io
```

#### `miner_stop`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miner_stop" id="miner_stop"></a>

Stops the mining process on the client.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - `true` if mining stops, or if the node is not mining

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"miner_stop","params":[],"id":1}' https://connect.bit-rock.io
```

### `NET` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#net-methods" id="net-methods"></a>

The `NET` API methods provide network-related information.

#### `net_enode`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#net_enode" id="net_enode"></a>

Returns the enode URL.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - enode URL of the node

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"net_enode","params":[],"id":1}' https://connect.bit-rock.io
```

#### `net_listening`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#net_listening" id="net_listening"></a>

Whether the client is actively listening for network connections.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *boolean* - indicates if the client is actively listening for network connections

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"net_listening","params":[],"id":53}' https://connect.bit-rock.io
```

#### `net_peerCount`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#net_peercount" id="net_peercount"></a>

Returns the number of peers currently connected to the client.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - number of connected peers in hexadecimal

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"net_peerCount","params":[],"id":53}' https://connect.bit-rock.io
```

### `TXPOOL` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#txpool-methods" id="txpool-methods"></a>

The `TXPOOL` API methods allow you to inspect the contents of the transaction pool.

note

The `TXPOOL` API methods are not enabled by default for JSON-RPC. To enable the `TXPOOL` API methods, use the `--rpc-http-api` or `--rpc-ws-api` options.

#### `txpool_besuPendingTransactions`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#txpool_besupendingtransactions" id="txpool_besupendingtransactions"></a>

Lists pending transactions that match the supplied filter conditions.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

* `numResults`: *number* - integer representing the maximum number of results to return
* `fields`: *object* - object of fields used to create the filter condition

Each field in the object corresponds to a field name containing an operator, and a value for the operator. A field name can only be specified once, and can only contain one operator. For example, you cannot query transactions with a gas price between 8 and 9 Gwei by using both the `gt` and `lt` operator in the same field name instance.

All filters must be satisfied for a transaction to be returned.

| Field name | Value                                              | Value type       | Supported operators |
| ---------- | -------------------------------------------------- | ---------------- | ------------------- |
| `from`     | Address of the sender.                             | *Data*, 20 bytes | `eq`                |
| `to`       | Address of the receiver, or `"contract_creation"`. | *Data*, 20 bytes | `eq`, `action`      |
| `gas`      | Gas provided by the sender.                        | *Quantity*       | `eq`, `gt`, `lt`    |
| `gasPrice` | Gas price, in wei, provided by the sender.         | *Quantity*       | `eq`, `gt`, `lt`    |
| `value`    | Value transferred, in wei.                         | *Quantity*       | `eq`, `gt`, `lt`    |
| `nonce`    | Number of transactions made by the sender.         | *Quantity*       | `eq`, `gt`, `lt`    |

Supported operators:

* `eq` (equal to)
* `lt` (less than)
* `gt` (greater than)
* `action`

note

The only supported `action` is `"contract_creation"`.

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of objects with details of the pending transaction

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"txpool_besuPendingTransactions","params":[2,{"from":{"eq":"0xfe3b557e8fb62b89f4916b721be55ceb828dbd73"},"gas":{"lt":"0x5209"},"nonce":{"gt":"0x1"}}],"id":1}' https://connect.bit-rock.io
```

#### `txpool_besuStatistics`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#txpool_besustatistics" id="txpool_besustatistics"></a>

Lists statistics about the node transaction pool.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *object* - transaction pool statistics object with the following fields:

* `maxSize`: *number* - maximum number of transactions kept in the transaction pool; use the [`--tx-pool-max-size`](https://about/stable/public-networks/reference/cli/options#tx-pool-max-size) option to configure the maximum size.
* `localCount`: *number* - number of transactions submitted directly to this node
* `remoteCount`: *number* - number of transactions received from remote nodes
* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"txpool_besuStatistics","params":[],"id":1}' https://connect.bit-rock.io
```

#### `txpool_besuTransactions`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#txpool_besutransactions" id="txpool_besutransactions"></a>

Lists transactions in the node transaction pool.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *array* of *objects* - list of transactions

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"txpool_besuTransactions","params":[],"id":1}' https://connect.bit-rock.io
```

### `WEB3` methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#web3-methods" id="web3-methods"></a>

The `WEB3` API methods provide functionality for the Ethereum ecosystem.

#### `web3_clientVersion`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#web3_clientversion" id="web3_clientversion"></a>

Returns the current client version.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - current client version

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":1}' https://connect.bit-rock.io
```

#### `web3_sha3`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#web3_sha3" id="web3_sha3"></a>

Returns a [SHA3](https://en.wikipedia.org/wiki/SHA-3) hash of the specified data. The result value is a [Keccak-256](https://keccak.team/keccak.html) hash, not the standardized SHA3-256.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`data`: *string* - data to convert to a SHA3 hash

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *string* - SHA3 result of the input data

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"web3_sha3","params":["0x68656c6c6f20776f726c00"],"id":53}' https://connect.bit-rock.io
```

### Miscellaneous methods[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#miscellaneous-methods" id="miscellaneous-methods"></a>

#### `rpc_modules`[​](https://docs.bit-rock.io/developer/broken-reference) <a href="#rpc_modules" id="rpc_modules"></a>

Lists enabled APIs and the version of each.

**Parameters**[**​**](https://docs.bit-rock.io/developer/broken-reference)

None

**Returns**[**​**](https://docs.bit-rock.io/developer/broken-reference)

`result`: *map* of *strings* to *strings* - enabled APIs and their versions

* curl HTTP request
* wscat WS request
* JSON result

```
curl -X POST --data '{"jsonrpc":"2.0","method":"rpc_modules","params":[],"id":1}' https://connect.bit-rock.io
```
