Skip to content

Latest commit

 

History

History
118 lines (87 loc) · 5 KB

making-changes.md

File metadata and controls

118 lines (87 loc) · 5 KB

Contributors Guide

This guide will explain for new and experienced contributors alike how to propose changes to Ethereum JSON-RPC API.

Introduction

The Ethereum JSON-RPC API is the canonical interface between users and the Ethereum network. Each execution layer client implements the API as defined by the spec.

As the main source of chain information, anything that is not provided over via API will not be easily accessible to users.

Guiding Principles

When considering a change to the API, it's important to keep a few guiding principles in mind.

Necessity

The most common path to a newly standardized method is necessity. As the protocol changes over time, new types of data become available. EIP-2930 necessitated the introduction of eth_accessList and EIP-1559 necessitated eth_feeHistory.

Therefore, a good question to ask before making a new API proposal is whether or not the method is strictly necessary. Sometimes the answer is yes even without a protocol change. For example, eth_getProof has been possible since the initial version of Ethereum -- yet, it was only standardized in recent years as demand for the functionality grew. Before eth_getProof, there was no interface for getting intermediary trie nodes over the API. This is a great example of a method that became more necessary over time.

Sometimes efficiency is the basis of necessity. If certain patterns of requests becomes popular, it can be advantageous to enshrine the behavior into the API.

Implementation Complexity

How a method is implemented should be carefully considered before proposing a change to the API. Although each client is able to validate the Ethereum chain, there can be a huge variance in actual design decisions.

As an example, a proposal for a method such as eth_totalSupply seems reasonable. This is a quantity that users are often interested in and it would nice to have it available. However, tracking the total supply is tricky. There are several avenues where ether can enter and leave supply. This method would need to either i) compute the value on demand or ii) store value for each block height.

Option i) is out, because it would involve executing each block starting with genesis. Option ii) is viable, but it starts enforcing certain requirements on clients beyond being able to simply validate the chain. Now during block ingestion, each client needs to store in their database the supply for that height. The chain reorg logic also needs to consider this new data. It is not trivial.

Backwards Compatibility

There is currently no accepted path to making backwards incompatible changes to the API. This means that proposals which change syntax or semantics of existing methods are unlikely to be accepted. A more viable approach is to propose a new method be created.

Standardization

There is not a formal process for standardization of API changes. However, the outline below should given proposal authors and champions a rough process to follow.

Idea

An often overlooked aspect on the standardization journey is the idea phase. This is an important period of time, because some focused effort at this point in time can save time and make the rest of the process much smoother.

During the idea phase, it is recommended to contemplate the proposal idea in the context of the guiding principles above. It's also good to get feedback on the idea in the open. Just one or two rough acknowledgements from client developers that an idea makes sense and is worth pursuing can avoid wasting a lot of time formalizing a proposal that has little chance of being accepted.

Proposal

The formal proposal stage is where the bulk of time will be spent. A formal proposal is a PR to this repository (ethereum/execution-apis). A good proposal will have the following:

  • a modification to the specification implementing the proposal
  • test cases for proposal (guide)
  • motivation for the change
  • links to acknowledgements that proposal idea is sound
  • clear rationale for non-obvious design decisions

Acquiring Support

Once a formal proposal has been created, formal support of clients can be acquired. This has historically been done via the AllCoreDevs call. It is recommended to post a request on the AllCoreDevs agenda (usually in ethereum/pm) to discuss the proposal, at which point formal support can be ascertained.

Oftentimes, support will be conditional on certain changes. This means that proposals will cycle between formal proposal work and earning support from clients. This should be expected and not discourage authors.

Accepting the Change

After client teams acknowledge and accept the change, it is usually on them to implement the method in their client. Due to the lack of versioning of the API, it is preferable that clients release the method roughly at the same time so that there is not much time where some clients support a certain methods and others don't.