Relay supports deposits to and withdrawals from Bitcoin across any supported chain. This guide covers the Bitcoin-specific parameters, PSBT signing, balance calculation, and API/SDK usage required for integration.Documentation Index
Fetch the complete documentation index at: https://docs.relay.link/llms.txt
Use this file to discover all available pages before exploring further.
Required Information
Bitcoin transactions differ from EVM chains in several ways. The sections below highlight the Bitcoin-specific parameters and requirements for your integration.SDK Properties
| Action | Parameter | Input | Description |
|---|---|---|---|
| Deposit to Bitcoin | toChainId | 8253038 | Chain ID assigned to Bitcoin in Relay. |
recipient | User’s Bitcoin Address | Valid Bitcoin address. | |
toCurrency | bc1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqmql8k8 | Native BTC identifier. | |
| Withdraw from Bitcoin | chainId | 8253038 | Chain ID assigned to Bitcoin in Relay. |
currency | bc1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqmql8k8 | Native BTC identifier. |
Bitcoin Currency
| Token | Currency Address | Symbol | Decimals |
|---|---|---|---|
| BTC | bc1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqmql8k8 | BTC | 8 |
PSBT Signing
Bitcoin transactions use Partially Signed Bitcoin Transactions (PSBT) for signing. When withdrawing from Bitcoin, the quote response returns a PSBT instead of standard EVM calldata. The Bitcoin wallet adapter handles PSBT parsing, finalization, and broadcasting. Provide asignPsbt
callback that signs the PSBT and returns the signed result in base64 format.
UTXOs and Bitcoin Balance
Unlike EVM chains that track account balances directly, Bitcoin uses a UTXO (Unspent Transaction Output) model. Each address balance equals the sum of unspent outputs it has received minus outputs it has spent. To calculate a Bitcoin address balance, query the mempool.space API and compute the difference between funded and spent transaction outputs:API
Params
| Action | Parameter | Input | Description |
|---|---|---|---|
| Deposit to Bitcoin | recipient | User’s Bitcoin Address | Valid Bitcoin address. |
destinationChainId | 8253038 | Chain ID assigned to Bitcoin in Relay. | |
destinationCurrency | bc1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqmql8k8 | Native BTC identifier. | |
| Withdraw from Bitcoin | user | User’s Bitcoin Address | Valid Bitcoin address. |
originChainId | 8253038 | Chain ID assigned to Bitcoin in Relay. | |
originCurrency | bc1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqmql8k8 | Native BTC identifier. |
Execution
Bitcoin uses the standard Relay API flow. Review the execution steps documentation, then use the Get Quote endpoint.Example: Withdraw from Bitcoin to Base
Example: Deposit to Bitcoin from Base
Amounts are specified in the smallest unit of the currency. For BTC,
this is satoshis (100000 satoshis = 0.001 BTC). For USDC, this is 6
decimal places (10000000 = 10 USDC).
SDK
To use the SDK with Bitcoin, install and configure the Bitcoin wallet adapter. The adapter handles PSBT signing and transaction broadcasting.Deposit Addresses (Optional)
Relay also supports the deposit address flow, which allows bridging without wallet connection or PSBT signing. When using deposit addresses, there are additional considerations:Block Confirmations
When using deposit addresses, Relay waits for 1 block confirmation before processing. Bitcoin’s block time averages ~10 minutes but varies significantly. blocks can arrive within minutes of each other or take 30-50 minutes.Quote Requirements for Deposit Addresses
When usinguseDepositAddress: true with Bitcoin as origin:
- The
useraddress must be a valid Bitcoin address - The
useraddress balance must exceed the quoted amount (otherwise returnsINSUFFICIENT_FUNDS) - For indicative quotes, use a known high-balance address (“whale address”). The actual deposit can originate from any address.