Multi-Chain
This guide covers usingChainContextHandle to operate on multiple blockchains from a single React Native SDK instance.
For an overview of multi-chain concepts, see Multi-Chain Concepts.
Setup
Initialize the parent SDK against your primary chain, then open a chain context for each additional chain:ChainContextConfig.chainId is a bigint and is required. Pass undefined for the optional fields to let the SDK discover them from the server.
Authentication
Each chain context needs to authenticate before it can operate. Authentication shares your privacy keys from the parent SDK but obtains a chain-specific JWT and registration:ChainContextHandle.authenticate() only takes a WalletDelegate — keySource and tokenProvider come from the parent SDK.
Operations
Once authenticated, aChainContextHandle exposes the same per-chain operations as the parent SDK:
Deposits
Private Transfers
Withdrawals
Balances
Status polling and history
Cross-Chain Patterns
Parallel Operations
Chain contexts are independent — run operations concurrently:Multi-Chain Balance Aggregation
Chain Selection
React Hook Pattern
Cleanup
Each chain context can drop its JWT independently while keeping the parent SDK identity intact:Next Steps
- Deposits Guide — detailed shield operations
- Withdrawals Guide — withdrawal operations
- Transfers Guide — private transfers
- Multi-Chain Concepts — architecture overview