Multichain Relayer Server
The Multichain Relayer Server facilitates cross-chain transactions and enables Chain Abstraction.
Overview
The main function of this server is interfacing with foreign chain RPCs sending both presigned funding transactions to cover gas and the actual presigned transaction once the funding is done.
Although the multichain relayer is a server in current design of this system, the goal is to package this as a library that can be called on the client side of the wallet. This will make the system more decentralized.
The Multichain Relayer is meant to be deployed alongside the Gas Station Event Indexer on the same server so that the Gas Station event indexer can call the Multichain Relayer server via IPC instead of having to send the request over the network introducing extra latency to the system.
Paymaster
A paymaster represents an address on a destination chain that holds a balance of that chain’s native gas token:
- User addresses on destination chains will be funded directly from paymaster accounts.
- Partners that want to integrate with the Multichain Gas Relayer service need to create, fund, and manage paymaster accounts on the destination chains that they want to have support for.
- Manual settlement between the NEAR Gas Station contract and paymaster accounts are also required on a regular basis to ensure a consistent balance of funds.
Multiple Paymaster accounts
If the relayer or transaction forwarder is fast enough, having only one Paymaster account might be enough.
Currently we don't have actual performance or usage data, so it's difficult to offer recommendations about multiple paymaster accounts.
For independent deployments of gas station contracts, generally, nonce synchronicity should be addressed using these three measures, in this order of preference:
- Users and clients of the smart contract submit signed payloads independently.
- This is the least reliable option; it is not wise to leave this up to the users, but it is potentially the lowest-latency option. Therefore, while this should be the first option in order of precedence, it must not be the only option.
- The relayer service picks up signed payloads and submits them to the remote chain.
- This relayer service provides the guarantee to the smart contract that signed payloads will make it to the remote chain and update the nonce.
- Using multiple paymaster accounts.
- This is a stopgap measure that essentially only serves as a small buffer in case the relayer service falls behind, or some of the paymaster nonces (temporarily) get out-of-sync. Adding more paymasters will not eliminate nonce synchronicity issues if they exist; it will only reduce latency for users while the system is working and experiencing high traffic.
System workflow
- The wallet sends a NEAR transaction to the gas station contract that contains 2 actions:
- A transfer of
NEAR
(or FT Transfer in the future) to cover gas on the foreign chain - A
create_transaction
function call to the gas station contractcanhazgas.testnet
containing the unsigned foreign chain transaction to be signed by the MPC signing service, assuming the unsigned transaction passes validation.(note:
mainnet
contract address iscanhazgas.near
)
- A transfer of
- The Gas Station Contract calls the MPC signing service to sign both a funding transaction, which ensures the user's foreign chain account has sufficient gas to execute the desired transaction, and signs the unsigned foreign chain transaction.
- Upon receipt of both the signed transactions, the Gas Station Contract emits an event which is picked up by the indexer, which then calls the
/send_funding_and_user_signed_txns
with the 2 signed transactions from the indexer. - The multichain relayer server sends the funding transaction to the foreign chain RPC to fund the user's account with gas.
- After the gas funding transaction is confirmed, the multichain relayer server calls the foreign chain RPC again to send the signed transaction initiated by the user in step 1.
- The cross-chain settlement takes care of selling the extra
NEAR
being sent to the gas station contract for gas tokens on foreign chains as well as bridging the tokens to the other chains. This process is currently manual, but will be automated in partnership with market makers in the future.
Relayer Server Endpoints
/send_funding_and_user_signed_txns
which handles both- Funding the user's XChain account with gas from the paymaster treasury account, which is provided as a raw signed transaction
- Sending the user's raw signed transaction (in hexadecimal in EVM case) after the funding transaction has been confirmed on the foreign chain
Supported Chains
Testnet
- Arbitrum (Ethereum Sepolia)
- Base (Ethereum Sepolia)
- BSC
- Ethereum (Sepolia)
- Optimism (Ethereum Sepolia)
Mainnet
- Arbitrum (Ethereum L2)
- Base (Ethereum L2)
- BSC
- Ethereum
- Optimism (Ethereum L2)
Check the Relayer's GitHub repository to learn more about upcoming features and updates.
Limitations
When using the Multichain Gas relayer solution, some limitations should be considered. Here's a list of potential issues you might encounter, and suggested ways to mitigate them:
- Not enough gas for a cross-chain transaction to get included in time.
- Solution: overcharge for gas at the gas station and when constructing the transaction include more than the average gas price.
- Slippage violations causing the gas token or foreign chain Fungible Token to get refunded to the user's foreign chain address.
- Solution: encourage your users to use high slippage settings in volatile or low liquidity market conditions.
- Solution: if such error occurs, make the user aware of what happened and that funds were not lost.
- Note: in future versions the solution will support retrying transactions.
- Nonce issues if Paymaster rotation isn't done properly. This issue is a function of concurrent usage, blockchain finality time, and the number of paymaster treasury accounts that the Gas Station is rotating through.
- Solution: use a blockchain that has faster finality.
- Solution: increase the number of paymaster treasury accounts through which the gas station rotates.
Total Time expectations for end users
It depends on the chain, but in our current estimation 50-90% of the time will be on NEAR calling and waiting for the signing to complete on the MPC service. The signing service will take 15-30 seconds. We assume that both the signing of the foreign chain transaction and the gas funding transaction happen in parallel.
BSC
On BSC mainnet (not beaconchain
which has 1 second finality) with 3 second blocktimes there should be 2 blocks for confirmation optimistically bringing the total to 6 seconds optimistically/transaction on BSC.
We need to make 2 transactions, so that's 12-24 seconds on BSC assuming 2-4 blocks for finality. Add in some network overhead for each step in the process, especially the indexer picking up the emitted event (~5-7 seconds), and we're at 30-60 seconds/transaction on BSC.
Solana
For Solana it would be closer to 20-30 seconds (0.4 second block time, 1 block confirmation). See table 1 for more confirmation times.
Ethereum L2s
L2 real finality times can be over a day for finality, unless we trust a centralized sequencer for soft confirmations, which may be as fast as a few seconds as in the case of zksync era.
The difference between optimistic or soft confirmations vs real finality is something we are considering. We may get better finalized guarantees when the Eigenlayer-Near Partnership is live. 3-4 second finality for all Ethereum L2s is much more manageable.