USDT0

Overview

Stable is an EVM-compatible Layer 1 blockchain where USDT0 serves as both the native asset and gas token, eliminating the need for a secondary token to fund transactions. Standard EVM tooling operates without modification on the Stable network. The chain supports ERC-3009 and x402 standards, enabling payment flows including P2P transactions, subscriptions, invoices, and pay-per-call mechanisms.

Explorer

https://stablescan.xyz/

Wallets Types

BitGo enables holding usdt0 in the following wallet types:

Multisig ColdMultisig HotMPC ColdMPC Hot
Custody
Self-Custody

Ticker Symbols

MainnetTestnet
USDT0TUSDT0

Faucet

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

Faucet: https://faucet.stable.xyz/

Units

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

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

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

Tokens

USDT0 supports the ERC20 token standard. ERC20 tokens on the Stable network are available as BitGo supported assets.

Fees

USDT0 supports EIP-1559 fee pricing. All transaction fees are paid in USDT0, the native asset of the Stable network. The base fee is the minimum price per unit of gas required for a transaction to be included in a block, and must be exceeded by the transaction's specified maximum base fee. A priority fee can be added on top of the base fee to incentivize faster processing.

Create Wallet

1 2 3 4 5 6 7 8 9 10 11 12 13 bitgo .coin("tusdt0") .wallets() .generateWallet({ label: "My Test Wallet", passphrase: "secretpassphrase1a5df8380e0e30", enterprise: "5612c2beeecf83610b621b90964448cd", walletVersion: 4, }) .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="tusdt0" 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": 4 }'

Create Address

1 2 3 4 5 6 7 8 9 10 11 bitgo .coin("tusdt0") .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/tusdt0/wallet/$WALLET/address

Consolidate Balance

USDT0 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 = process.env.ACCESS_TOKEN; const coin = "tusdt0"; 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="tusdt0" 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="tusdt0" 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

USDT0 isn't a stakeable asset.