The Ethereum Distribution System (EDS) is an open and decentralized, fully on-chain distribution (factory) system for Ethereum smart contracts. Using EDS enables developers to publish and reuse each other's code in a trustless manner. Built-in system for semantic versioning, managing versions and combining into higher level distributions allows developers to avoid using upgradability patterns, instead relying on version control. System provisions for generic interfaces for distributors, developers and installers, each with their own responsibilities and constraints.
- Factory Framework: Instead of writing own factory, just write a distribution and register it
- Ship faster: Reduce the number of needed deployment artifacts to ship your project. Re-using other packages instead!
- Security oracles: Disconnect vulnerable code from your users in O(1)
- Semantic versioning with EIP712: Instead of having to figure out "what to write in EIP712 constructor" just use the built in version control system!
- User owned upgradability: Get more user trust by allowing them to decide when to upgrade
- Improve user UX: Configure trust within instance or distribution, so that your users do not need to set allowances and issue permits anymore!
- On-chain github: Refer bytecode instead of location using (ERC7744)
- Better Monetize your apps and services: As your application becomes distributed, and wrapped, you may directly build in payment systems and subscription models on-chain!
This system acts as a generalized and efficient factory which is designed in one-fits-all principle. It achieves this by splitting EDS users in following groups:
- Developers: Create a distributable (stateless) software that can be instantiated. It can use already deployed contracts and functionality!
- Distributors: Security firms and traditional distributor agencies. Ensure that distributions they list are secure (think of this as a runtime checked audit attestation), trusted and act in their user interest!
- Smart accounts: Use Distributor software to plug it into your smart account!
IN the background, there is extensive use of proxies to map instances, that are proxies, to a right functionality. Instances are also treated as middlewares that are hooked to the distributor with use of ERC7746, in such a way that the caller cannot reach the functionality without first checking with the distributor. The distributor in turn, by default, checks if the instance is a valid distribution. If the developer wants to manage multiple versions of the same resource, they can create a Repository contract to add their own index on top of global.
We are open for discussion, whether this should be managed trough a governing body as a DAO.
If you want to be up to date, express your opinion or not miss a thing, please
- subscribe to our twitter: https://x.com/peeramid_labs
- join our discord: https://discord.gg/EddGgGUuWC
- Verifiable: Stateless distribution components are easily verifiable by anyone through their bytecode.
- Permission-less: Anyone can deploy distribution components without requiring permissions.
- Inclusive: Can accommodate already deployed on-chain functionality.
- Versionable: Semver based versioning can be applied to manage resources.
- Plug-n-Play: Installation procedures,easily customizable for any target platform are provisioned.
- Secure: Isolated contract sets and baked-in runtime checks enable trust chain between developers, distributors and users.
- Efficient: Extensive reuse of the same bytecode reduces gas costs, increasing efficiency across the industry.
System components are broken down into four domains: Permission-less, Developer, Distributor and User. Each domain has its own set of contracts and interfaces, which are designed to work together to provide a seamless experience for developers and users.
CodeIndex (ERC-7744)
A stateful, permission less contract allowing anyone to register associations between bytecode and its on-chain location. Any smart contract may be indexed by CodeIndex
based on its bytecode.
Proposed CREATE2
implementation with deterministic address : 0xC0dE1D2F7662c63796E544B2647b2A94EE658E07
Interface for contracts that allow specific mechanics of instantiation of referred bytecode identifiers in the CodeIndex
. It may be using different methods for instantiation, yet it is ultimately referred by it's bytecode hash and instantiation methods kept non-parametric, to promote hardcoding of instantiation logic by the distribution creator, ultimately making any distribution a unique part of code ecosystem.
It also allows distribution creators to associate own metadata with the distribution, such as URIs defined in ERC-190 or ERC-2678
Repositories are interfaces provided for stateful, permissioned contracts allowing developers to manage resources and versions. Such repositories may return any kind of source code reference, including system-internal used ones, like IDistribution
. It allows developers to increment versions according to Semver as well as implement version requirements lookup for the clients.
Any implementation of Distribution interface mentioned in the Permission-less Domain, that is stateful is considered as a Developer Domain component. It is possible in principle, yet will be used only for specific use-cases, where stateful distribution is required and will require distribution users to use direct location addressing, effectively excluding it from the global index system.
Stateful, permissioned contract interface for managing distributions. It allows distributors, who may act as trusted source for many, to have their own index of trusted distributions coupled to any, parametric, initialization logic that they might need. This is a first point on instantiation chain that allows to configure distribution after it's been instantiated.
Same as Distributor, but with additional functionality to manage versions of distributions. It allows to manage multiple versions of the same distribution and to provide version requirements lookup for the clients. Distributor may change the version of the repository, effectively disabling, in one go, every outdated version instances from operating in the system.
Stateful, permissioned contracts for managing permissions and accessing targets from multiple distributors. Allows end-users to manage trusted sources for their installations.
pnpm install
pnpm test # Run tests
Examples of distributions usage can be found in src/distributions directory. Examples of repositories usage can be found in src/repositories directory. Examples of distributors usage can be found in src/distributors directory.
Larger example of usage can be found in Rankify project repo
If you want to support this project, please click "sponsor" button, or see our gitcoin page: https://explorer.gitcoin.co/#/projects/0xd4427d0ffc2b8f58c4ef28410deed1158a7d5e405d6cd5bedb0487441d2ba452
You can reach out us on Discord: https://discord.gg/EddGgGUuWC