Skip to content

Commit

Permalink
Update multichain-server article (#2172)
Browse files Browse the repository at this point in the history
* Update multichain-server.md

* Update overview.md
  • Loading branch information
bucanero authored Jul 26, 2024
1 parent ee75fe4 commit 8a70e70
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,6 @@ sidebar_label: Multichain Gas Station Contract

The [multichain gas station smart contract](https://github.com/near/multichain-gas-station-contract) accepts payments in NEAR tokens in exchange for gas funding on non-NEAR foreign chains. Part of the NEAR Multichain effort, it works in conjunction with the [MPC recovery service](https://github.com/near/mpc-recovery) to generate on-chain signatures.

:::info Alpha stage

The Multichain Relayer solution is currently under development. Users who want to test-drive this solution should keep in mind that the product is in alpha stage, and a code audit is pending.

:::

## What is it?

This smart contract is a piece of the NEAR Multichain project, which makes NEAR Protocol an effortlessly cross-chain network. This contract accepts EVM transaction request payloads and facilitates the signing, gas funding, and relaying of the signed transactions to their destination chains. It works in conjunction with a few different services, including:
Expand Down Expand Up @@ -97,6 +91,17 @@ You can review the complete smart contract source code in [this GitHub repositor
- Pyth oracle price fee IDs can be [found here](https://pyth.network/developers/price-feed-ids)
4. Add paymasters to each foreign chain with `add_paymaster`.

### Price Pusher

In order to get up-to-date information on gas prices for foreign chains, a price pusher service must be run, either on demand or as a `cron` job.

Suggested tools:
- [Pyth Price Pusher](https://github.com/pyth-network/pyth-crosschain/tree/main/apps/price_pusher): this price pusher supports `BNB` and `ETH`

:::tip
A separate price pusher should be used for each token.
:::

### Usage

Users who wish to get transactions signed and relayed by this contract and its accompanying infrastructure should perform the following steps:
Expand All @@ -110,9 +115,11 @@ Users who wish to get transactions signed and relayed by this contract and its a
- Repeat `pending_transactions_count` times.
4. Relay each signed payload to the foreign chain RPC in the order they were requested.

:::tip testnet contract
:::tip Contract address

If you want to try things out, this smart contract is available on `canhazgas.testnet`.
If you want to try things out, this smart contract is available on:
- testnet: `canhazgas.testnet`
- mainnet: `TBD`

:::

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,20 +6,14 @@ sidebar_label: Multichain Relayer Server

The [Multichain Relayer Server](https://github.com/near/multichain-relayer-server) facilitates cross-chain transactions and enables Chain Abstraction.

:::info Alpha stage

The Multichain Relayer solution is currently under development. Users who want to test-drive this solution should keep in mind that the product is in alpha stage, and a code audit is pending.

:::

## 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.

:::tip
The Multichain Relayer is meant to be deployed alongside the [Gas Station Event Indexer](https://github.com/near/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.
The Multichain Relayer is meant to be deployed alongside the [Gas Station Event Indexer](https://github.com/near/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
Expand Down Expand Up @@ -68,8 +62,21 @@ For independent deployments of gas station contracts, generally, nonce synchroni

## Supported Chains

- BSC testnet
- BSC mainnet, Ethereum mainnet, and more chains coming soon!
#### 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)

:::info
Check the Relayer's [GitHub repository](https://github.com/near/multichain-relayer-server) to learn more about upcoming features and updates.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ Below is a design diagram of the entire Multichain Relayer system:

- The [gas station contract](gas-station.md) and the [MPC signing service contract](https://github.com/near/mpc-recovery/tree/main/contract) are in the green box which take place on NEAR.
- The [multichain relayer server](multichain-server.md) focuses on the blue _Multichain Relayer Core Backend Services_ box in the middle and the connections to the XChain systems in the red box via RPCs.
- The [XChain Settlement](gas-station.md#settlement) process happening in the yellow box can be either manual or automated. Automated settlement is available for select partners based on their xChain transaction volume.
- The [XChain Settlement](gas-station.md#settlement) process happening in the yellow box can be either manual or automated. [Automated settlement](gas-station.md#automated-settlement) is available for select partners based on their xChain transaction volume.

:::

Expand All @@ -60,7 +60,7 @@ Below is a design diagram of the entire Multichain Relayer system:

- **Paymaster Accounts**: These are accounts on the destination chains that hold the native gas tokens. They ensure users have enough gas to complete their transactions on foreign chains.
- **xChain Settlement**: regular [cross-chain settlement](gas-station.md#settlement) is needed to ensure paymaster accounts have sufficient funds. This can be manual or automated, and involves swapping NEAR tokens for foreign chain tokens and transferring them to the paymaster accounts.
- Automated settlement is available for select partners based on their cross-chain transaction volume.
- [Automated settlement](gas-station.md#automated-settlement) is available for select partners based on their cross-chain transaction volume.
- **Supported Chains**: Initially supports BSC, Ethereum, Base, Arbitrum, and Optimism with plans to expand to other chains.

## Limitations and Considerations
Expand Down

0 comments on commit 8a70e70

Please sign in to comment.