zkSync Era

Overview

zkSync Era is a ZK Rollup–based Ethereum Layer 2 that provides EVM compatibility with significantly reduced transaction fees. Transactions are executed off-chain by the sequencer, with validity proofs submitted to Ethereum L1 to achieve finality. zkSync Era supports standard Ethereum addresses (0x-prefixed, EIP-55 checksummed), ECDSA signing, and ERC-20 tokens.

Network Information

ConfigurationMainnetTestnet (zkSync Era Sepolia)
Block Explorerhttps://explorer.zksync.iohttps://sepolia.explorer.zksync.io
Chain ID324300
Currency SymbolETHETH
Layer 1Ethereum MainnetSepolia Testnet
Network NamezkSync Era MainnetzkSync Era Sepolia Testnet
RPC URLhttps://mainnet.era.zksync.iohttps://sepolia.era.zksync.dev

Explorer

https://explorer.zksync.io/

Wallets Types

BitGo enables holding zksyncera in the following wallet types:

Multisig ColdMultisig HotMPC ColdMPC Hot
Custody
Self-Custody

Ticker Symbols

MainnetTestnet
ZKSYNCERATZKSYNCERA

Faucet

You can use a faucet to obtain free testnet tzksyncera for development and testing purposes.

Faucet: https://portal.zksync.io/faucet

Units

Each zkSync Era is comprised of 1,000,000,000,000,000,000 (1018) wei, so not even a single zkSync Era can be stored numerically without exceeding the range of JavaScript numbers. Gas fees are denoted in gwei.

  • 1 zksyncera = 1018 wei
  • 1 wei = 10-18 zksyncera
  • 1 gwei = 10-9 zksyncera

For that reason, only string balance properties are available, which are balanceString, confirmedBalanceString, and spendableBalanceString.

Fees

zkSync Era uses a unique fee model based on the EIP-1559 transaction format for compatibility, but its internal fee mechanism uses eth_gasPrice rather than standard EIP-1559 fee history. The effective gas price from eth_gasPrice already includes L2 execution costs and L1 calldata publication overhead. Fees are paid exclusively in ETH. There is no traditional baseFeePerGas; instead, the gas price bundles all fee components — L2 execution, L1 calldata, and prover overhead — into a single value.

Create Wallet

1 2 3 4 5 6 7 8 9 10 11 12 13 bitgo .coin('tzksyncera') .wallets() .generateWallet({ label: 'My Test Wallet', passphrase: 'secretpassphrase1a5df8380e0e30', enterprise: '5612c2beeecf83610b621b90964448cd', walletVersion: 3, }) .then(function (wallet) { // print the new wallet console.dir(wallet); });
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 export BITGO_EXPRESS_HOST="<YOUR_LOCALHOST>" export COIN="tzksyncera" export ACCESS_TOKEN="<YOUR_ACCESS_TOKEN>" export LABEL="<DESIRED_WALLET_NAME>" export PASSPHRASE="<YOUR_BITGO_LOGIN_PASSPHRASE>" export ENTERPRISE_ID="<YOUR_ENTERPRISE_ID>" curl -X POST \ http://$BITGO_EXPRESS_HOST/api/v2/$COIN/wallet/generate \ -H 'Content-Type: application/json' \ -H "Authorization: Bearer $ACCESS_TOKEN" \ -d '{ "label": "'"$LABEL"'", "passphrase": "'"$PASSPHRASE"'", "enterprise": "'"$ENTERPRISE_ID"'", "walletVersion": 3 }'

Create Address

1 2 3 4 5 6 7 8 9 10 11 bitgo .coin('tzksyncera') .wallets() .getWallet({ id: '585c51a5df8380e0e3082e46' }) .then(function (wallet) { return wallet.createAddress(); }) .then(function (newAddress) { // print new address details console.dir(newAddress); });
1 2 3 4 5 6 export WALLET="585c51a5df8380e0e3082e46" export ACCESS_TOKEN="<YOUR_ACCESS_TOKEN>" curl -X POST \ -H "Authorization: Bearer $ACCESS_TOKEN" \ https://app.bitgo-test.com/api/v2/tzksyncera/wallet/$WALLET/address

Consolidate Balance

zkSync Era supports Multisignature smart-contract wallets which utilize forwarder smart contracts to enable multiple receive addresses. The forwarder smart contract automatically consolidates native tokens received in your receive addresses to your base address. However, if you receive non-native tokens, such as ERC20 tokens, a different consolidation transaction will be initiated to the base address. Additionally, forwarders can only send assets to the base address of the wallet.

Estimate Fee

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 const BitGoJS = require('../../../src/index.js'); const bitgo = new BitGoJS.BitGo({ env: 'test' }); const accessToken = '<YOUR_ACCESS_TOKEN>'; const coin = 'tzksyncera'; async function getFeeEstimate() { try { await bitgo.authenticateWithAccessToken({ accessToken }); const res = await bitgo.coin(coin).feeEstimate({ numBlocks: 2 }); console.dir(res); } catch (err) { console.error('Error fetching fee estimate:', err); } } getFeeEstimate();
1 2 3 4 5 6 7 export COIN="tzksyncera" export ACCESS_TOKEN="<YOUR_ACCESS_TOKEN>" curl -X GET \ https://app.bitgo-test.com/api/v2/$COIN/tx/fee \ -H 'Content-Type: application/json' \ -H "Authorization: Bearer $ACCESS_TOKEN"

Transact

1 2 3 4 5 const tx = await fundedWallet.send({ address: '<DESTINATION_ADDRESS>', amount: '<AMOUNT>', walletPassphrase: process.env.PASSWORD, });
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 export BITGO_EXPRESS_HOST="<YOUR_LOCALHOST>" export COIN="tzksyncera" export WALLET_ID="<YOUR_WALLET_ID>" export ACCESS_TOKEN="<YOUR_ACCESS_TOKEN>" export ADDRESS="<DESTINATION_ADDRESS>" export AMOUNT="<AMOUNT_IN_BASE_UNITS>" export WALLET_PASSPHRASE="<YOUR_WALLET_PASSPHRASE>" curl -X POST \ http://$BITGO_EXPRESS_HOST/api/v2/$COIN/wallet/$WALLET_ID/sendcoins \ -H 'Content-Type: application/json' \ -H "Authorization: Bearer $ACCESS_TOKEN" \ -d '{ "address": "'"$ADDRESS"'", "amount": "'"$AMOUNT"'", "walletPassphrase": "'"$WALLET_PASSPHRASE"'" }'

Stake

zkSync Era isn't a stakeable asset.