An RPC method for adding Ethereum chains to wallet applications.
## Abstract
The `wallet_addEthereumChain` RPC method allows Ethereum applications ("dapps") to suggest chains to be added to the wallet application.
The caller must specify a chain ID and some chain metadata.
The wallet application may arbitrarily refuse or accept the request.
`null` is returned if the chain was added, and an error otherwise.
Important cautions for implementers of this method are included in the [Security Considerations](#security-considerations) section.
## Motivation
A dapp may require the user to interact with multiple Ethereum chains in order to function.
A may or may not be supported by the user's wallet application.
`wallet_addEthereumChain` enables dapps to request any necessary chains to be added to the user's wallet.
This provides UX benefits for dapps and wallets that want to provide such functionality.
## Specification
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC-2119](https://www.ietf.org/rfc/rfc2119.txt).
### `wallet_addEthereumChain`
The method accepts a single object parameter, with a `chainId` and some chain metadata.
The method returns `null` if the chain was added to the wallet, and an error otherwise.
The wallet **MAY** reject the request for any reason.
The wallet **MUST** reject the request if the `chainId` is improperly formatted.
The wallet **MUST** reject the request if the wallet does not support the chain with the specified `chainId`.
> Note that this method makes **no** statement about whether the wallet should change the user's currently selected chain, if the wallet has a concept thereof.
#### Parameters
`wallet_addEthereumChain` accepts a single object parameter, specified by the following TypeScript interface:
Only the `chainId` is required per this specification, but a wallet **MAY** require any other fields listed, impose additional requirements on them, or ignore them outright.
The design of `wallet_addEthereumChain` is deliberately ignorant of what it means to "add" a chain to a wallet.
The meaning of "adding" a chain to a wallet depends on the wallet implementation.
Ultimately, neither the user nor the dapp can now whether adding the chain "worked" until they have successfully interacted with it.
When calling the method, specifying the `chainId` will always be necessary, since in the universe of Ethereum chains, the [EIP-155](./eip-155.md) chain ID is effectively the GUID of a chain.
The remaining parameters amount to what, in the estimation of authors, a wallet will minimally require in order to effectively support a chain and accurately represent it to the user.
The network ID (per the `net_version` RPC method) was omitted since it is effectively superseded by the chain ID.
For [security reasons](#security-considerations), a wallet should always attempt to validate the chain metadata provided by the dapp, and may choose to fetch the metadata elsewhere entirely.
Either way, there's no way to know what the wallet will _need_ with respect to the chain metadata.
Therefore, all parameters except `chainId` are listed as optional, even though a wallet may require them in practice.
This specification does not mandate that the wallet "switches" its active chain, if the result is successful.
For related work, see [EIP-2015](./eip-2015.md).
## Security Considerations
`wallet_addEthereumChain` is a powerful method that exposes the end user to serious risks if implemented incorrectly.
Most of these risks can be avoided by validating the request data in the wallet, and clearly disambiguating different chains in the wallet UI.
### Chain IDs
Since the chain ID used for signing determines which chain a transaction is valid for, handling the chain ID correctly is of utmost importance.
The wallet should:
- Ensure that a submitted chain ID is valid.
- It should be submitted as a `0x`-prefixed hexadecimal string per [EIP-695](./eip-695.md), and parse to an integer number.
- Clearly inform the user which RPC URL is being used to communicate with a chain at any given moment, and inform the user of the risks of using multiple RPC endpoints to interact with the same chain.
Adding a new chain to the wallet can have significant implications for the functionality of the wallet and the experience of the user.
A chain should never be added without the explicit consent of the user, and different chains should be clearly differentiated in the wallet UI.
In service of these goals, the wallet should:
- When receiving a `wallet_addEthereumChain` request, display a user confirmation informing the user that a specific dapp has requested that the chain be added.
- The confirmation used in [EIP-1102](./eip-1102.md) may serve as a point of reference.
- If the wallet UI has a concept of a "currently selected" or "currently active" chain, ensure that the user understands when a chain added using `wallet_addEthereumChain` becomes selected.
### Validating Chain Data
A wallet that implements `wallet_addEthereumChain` should expect to encounter requests for chains completely unknown to the wallet maintainers.
That said, community resources exist that can be leveraged to verify requests for many Ethereum chains.
The wallet should maintain a list of known chains, and verify requests add chains against that list.
Indeed, unless there are good reasons not to, the wallet should _prefer its own chain metadata_ over anything submitted with a `wallet_addEthereumChain` request.
## Copyright
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).