Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zilm13/serenitypool
Eth2 pool with shared ownership
https://github.com/zilm13/serenitypool
Last synced: 27 days ago
JSON representation
Eth2 pool with shared ownership
- Host: GitHub
- URL: https://github.com/zilm13/serenitypool
- Owner: zilm13
- License: mit
- Created: 2020-12-19T16:17:11.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-07-05T09:32:37.000Z (over 3 years ago)
- Last Synced: 2024-10-29T01:04:12.429Z (3 months ago)
- Language: Solidity
- Size: 107 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SerenityPool [WIP]
PoC (Proof of Concept) of Eth2 pool with shared validator funding and control made to validate system contract design and requirements.Users deposit any amount of money, which is fractional to the whole validator deposit, user funds are combined for a whole validator deposit, deposit is submitted and users are guaranteed to get a share of their investment after validator exit and withdrawal is initiated and processed. During the validator's active life user could split or sell his share, which is similar to bond without intermediate coupons but with guaranteed time of examination.
Validator should be run by service which shouldn't disclose validator private key but is guaranteed to get their fees on exit. It's questionable if there is a way to protect users' investments from validator slashing as whole validator work is done off-chain, though at least slashing insurance pool could be tried on.
---Start development with
```shell
npm install
```### contracts/
- **SerenityPool** - Main pool contract
- **WithdrawalContract** - Withdrawal target contract
- **SystemContract** - Mock of withdrawal system contract which is going to be system contract on Eth1 handling withdrawals### test/
Truffle tests for all contracts, run with
```shell
truffle test
```### util/
Various utilities to make tests possible. Helpers for generation of fixtures. Run util tests with
```shell
cd util
npm test
```