Skip to main content

eth_call

Executes a new message call immediately without creating a transaction on Bittensor. Used for reading smart contract state.

Why Bittensor? Build on the decentralized AI network with $3.9B+ market cap powering 80+ AI subnets with Yuma Consensus for AI model evaluation, subnet-based specialization, dual Substrate+EVM support, and incentivized AI compute marketplace.

Use Cases#

The eth_call method is essential for:

  • Reading contract state - Query view/pure functions
  • Simulating transactions - Test execution without gas costs
  • DeFi integrations - Check prices, balances, allowances for decentralized AI inference, subnet-specific AI models, TAO staking, and cross-subnet AI collaboration
  • Complex queries - Execute multi-step contract logic

Parameters#

ParameterTypeRequiredDescription
fromDATANo20-byte address executing the call
toDATAYes20-byte contract address
gasQUANTITYNoGas limit for the call
gasPriceQUANTITYNoGas price in wei
valueQUANTITYNoValue to send in wei
dataDATAYesEncoded function call data
blockParameterQUANTITY|TAGYesBlock number or tag

Request#

{
"jsonrpc": "2.0",
"method": "eth_call",
"params": [
{
"to": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"data": "0x70a08231000000000000000000000000"
},
"latest"
],
"id": 1
}

Returns#

TypeDescription
DATAThe return value of the executed contract function

Response#

{
"jsonrpc": "2.0",
"id": 1,
"result": "0x0000000000000000000000000000000000000000000000000de0b6b3a7640000"
}

Code Examples#

# Call ERC20 balanceOf function
curl -X POST https://api-bittensor-mainnet.n.dwellir.com/YOUR_API_KEY \
-H "Content-Type: application/json" \
-d '{
"jsonrpc": "2.0",
"method": "eth_call",
"params": [{
"to": "5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY",
"data": "0x70a08231000000000000000000000000"
}, "latest"],
"id": 1
}'

Error Handling#

Error CodeMessageDescription
-32000Execution revertedContract function reverted
-32602Invalid parametersInvalid data encoding
-32015VM execution errorContract logic error