Skip to main content
POST
/
0a9d79d93fb2f4a4b1e04695da2b77a7
web3_clientVersion
curl --request POST \
  --url https://nd-422-757-666.p2pify.com/0a9d79d93fb2f4a4b1e04695da2b77a7 \
  --header 'Content-Type: application/json' \
  --data '
{
  "id": 1,
  "jsonrpc": "2.0",
  "method": "web3_clientVersion",
  "params": []
}
'
{
  "jsonrpc": "<string>",
  "id": 123,
  "result": "<string>"
}
Ethereum API method that returns the client type and version running on the Ethereum node. This information can be useful to developers to verify that a node they are connecting to is compatible with their needs.
Get your own node endpoint todayStart for free and get your app to production levels immediately. No credit card required.You can sign up with your GitHub, X, Google, or Microsoft account.

Parameters

  • none

Response

  • string — a string identifying the type of client, version, operating system, and language version running on the node

web3_clientVersion code examples

Learn more about the ChainstackProvider in ethers.js: ethers ChainstackProvider Documentation.
const ethers = require("ethers");

// Create a ChainstackProvider instance for Ethereum mainnet
const chainstack = new ethers.ChainstackProvider("mainnet");

const clientVersion = async () => {
  const version = await chainstack.send("web3_clientVersion");
  console.log(`Client version: ${version}`);
};

clientVersion();

Use case

A use case for the web3_clientVersion method can be to verify which client is running to then decide which method to run. Let’s say you have a DApp that needs to retrieve all of the transaction receipts in a block; the Erigon client has a method for this, eth_getBlockReceipts, but with Geth, this method is only available starting from V1.13.0. You can use the web3_clientVersion method in your logic to identify which client you are using to see if you have the method available.
Read Expanding your blockchain horizons: The eth_getBlockReceipts emulator to learn how to build a program to emulate eth_getBlockReceipts on any EVM-compatible chain.
Here is an implementation of this use case using ethers.js:
index.js
const ethers = require("ethers");

// Create a ChainstackProvider instance for Ethereum mainnet
const chainstack = new ethers.ChainstackProvider("mainnet");

// Call eth_getBlockReceipts, which has no dedicated ethers helper
async function getBlockReceipts(blockNumber) {
  return chainstack.send("eth_getBlockReceipts", [blockNumber]);
}

// Get client version
async function getClient() {
  const client = await chainstack.send("web3_clientVersion", []);
  return client;
}

// Extract the client's name and version
async function getClientName() {
  const clientVersion = await getClient();
  
  // Split the clientVersion string by '/'
  let parts = clientVersion.split('/');
  
  // Split the second part by '-' and take the first element
  let version = parts[1].split('-')[0];

  // Concatenate the client name and version
  let clientNameWithVersion = parts[0] + '/' + version;
  console.log(clientNameWithVersion);
  return clientNameWithVersion;
}

// Parse version from version string
function parseVersion(versionString) {
  const versionMatch = versionString.match(/(\d+\.\d+\.\d+)/);
  return versionMatch ? versionMatch[1] : null;
}

// Compare versions
function isVersionGreaterThanOrEqual(v1, v2) {
  const v1Parts = v1.split('.').map(Number);
  const v2Parts = v2.split('.').map(Number);

  for (let i = 0; i < Math.max(v1Parts.length, v2Parts.length); i++) {
    const num1 = v1Parts[i] || 0;
    const num2 = v2Parts[i] || 0;

    if (num1 > num2) return true;
    if (num1 < num2) return false;
  }
  return true; // versions are equal
}

// Get the receipts based on the client
async function getAllReceipts(blockId) {
  const clientNameWithVersion = await getClientName();
  const [clientName, clientVersion] = clientNameWithVersion.split('/');

  if (clientName === 'Geth') {
    const version = parseVersion(clientVersion);
    if (isVersionGreaterThanOrEqual(version, '1.13.0')) {
      console.log('Client is Geth with supported version.');
      const receipts = await getBlockReceipts(blockId);
    return receipts;
    } else {
      console.log('Client is Geth, but version is not supported.');
    }
  } else if (clientName === 'erigon') {
    console.log('Client is Erigon');
    const receipts = await getBlockReceipts(blockId);
    return receipts;
  } else {
    console.log('Client version is not Geth or Erigon');
  }
}

async function main() {
  try {
    const receipts = await getAllReceipts('latest');
    if (receipts !== undefined) {
      console.log(receipts);
    }
  } catch (error) {
    console.error(error);
  }
}

main();
Let’s break down the code:
  1. The getBlockReceipts Method:
    The getBlockReceipts function is a helper that calls the eth_getBlockReceipts JSON-RPC method directly with chainstack.send, passing a single parameter blockNumber. Because ethers.js does not expose a dedicated helper for this method, provider.send is used to issue the raw JSON-RPC call and return the resulting receipts.
  2. The getClient Function:
    This function retrieves the client version by calling the web3_clientVersion JSON-RPC method without parameters through chainstack.send. It returns the full client version string.
  3. The getClientName Function:
    getClientName calls getClient to get the complete client version string. It then extracts both the client’s name and its version by splitting the version string at the first / and - characters. The function concatenates these parts to form a string in the format “ClientName/Version”.
  4. The getAllReceipts Function:
    This function uses getClientName to retrieve the name and version of the client in a combined format. It checks if the client is Geth and, if so, further verifies whether its version is greater than or equal to 1.13.0 using the parseVersion and isVersionGreaterThanOrEqual functions. If the client is Geth with a supported version or Erigon, the function proceeds to fetch block receipts using the getBlockReceipts helper. If the client is neither a supported version of Geth nor Erigon, it logs a message indicating this.
  5. Version Parsing and Comparison:
    Additional functions parseVersion and isVersionGreaterThanOrEqual are included for parsing the version string and comparing it against a specified minimum version. parseVersion extracts the semantic version number from the client version string, and isVersionGreaterThanOrEqual compares this version against the specified minimum version, 1.13.0 in this case.
  6. Main Function and Execution Flow:
    The main function serves as the entry point for execution. It attempts to call getAllReceipts with a specified block identifier, handling any exceptions and logging the results if available.

Body

application/json
id
integer
default:1
jsonrpc
string
default:2.0
method
string
default:web3_clientVersion
params
array

Response

200 - application/json

The client running on this node.

jsonrpc
string
id
integer
result
string
Last modified on June 25, 2026