Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Layr-Labs/hello-world-avs
Hello World AVS
https://github.com/Layr-Labs/hello-world-avs
Last synced: 3 months ago
JSON representation
Hello World AVS
- Host: GitHub
- URL: https://github.com/Layr-Labs/hello-world-avs
- Owner: Layr-Labs
- License: mit
- Created: 2024-05-13T12:28:12.000Z (8 months ago)
- Default Branch: master
- Last Pushed: 2024-05-25T21:59:40.000Z (7 months ago)
- Last Synced: 2024-05-30T02:35:11.146Z (7 months ago)
- Language: TypeScript
- Size: 9.98 MB
- Stars: 20
- Watchers: 2
- Forks: 10
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-avs - Hello World AVS
- awesome-avs - Hello World AVS
README
# Hello World AVS
Welcome to the Hello World AVS. This project shows you the simplest functionality you can expect from an AVS. It will give you a concrete understanding of the basic components. For new users, please find [this video walkthrough](https://drive.google.com/file/d/1P6uA6kYWCbpeorTjADuoTlQ-q8uqwPZf/view?usp=sharing) of the hello world AVS repository.
## Architecture
![hello-world-png](./assets/hello-world-diagramv2.png)
### AVS User Flow
1) AVS consumer requests a "Hello World" message to be generated and signed.
2) HelloWorld contract receives the request and emits a NewTaskCreated event for the request.
3) All Operators who are registered to the AVS and has staked, delegated assets takes this request. Operator generates the requested message, hashes it, and signs the hash with their private key.
4) Each Operator submits their signed hash back to the HelloWorld AVS contract.
5) If the Operator is registered to the AVS and has the minimum needed stake, the submission is accepted.That's it. This simple flow highlights some of the core mechanics of how AVSs work.
# Local Devnet Deployment
The following instructions explain how to manually deploy the AVS from scratch including EigenLayer and AVS specific contracts using Foundry (forge) to a local anvil chain, and start Typescript Operator application and tasks.
Install dependencies:
- [Node](https://nodejs.org/en/download/)
- [Typescript](https://www.typescriptlang.org/download)
- [ts-node](https://www.npmjs.com/package/ts-node)
- [tcs](https://www.npmjs.com/package/tcs#installation)
- [npm](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm)
- [Foundry](https://getfoundry.sh/)
- [ethers](https://www.npmjs.com/package/ethers)### Start Anvil Chain
In terminal window #1, execute the following commands:
```sh
# Install npm packages
npm install# Start local anvil chain
npm run start:anvil
```### Deploy Contracts and Start Operator
Open a separate terminal window #2, execute the following commands
```sh
# Setup .env file
cp .env.example .env
cp contracts/.env.example contracts/.env# Updates dependencies if necessary and builds the contracts
npm run build# Deploy the EigenLayer contracts
npm run deploy:core# Deploy the Hello World AVS contracts
npm run deploy:hello-world# (Optional) Update ABIs
npm run extract:abis# Start the Operator application
npm run start:operator```
### Create Hello-World-AVS Tasks
Open a separate terminal window #3, execute the following commands
```sh
# Start the createNewTasks application
npm run start:traffic
```### Help and Support
For help and support deploying and modifying this repo for your AVS, please:
1. Open a ticket via the intercom link at [support.eigenlayer.xyz](https://support.eigenlayer.xyz).
2. Include the necessary troubleshooting information for your environment:
* Local anvil testing:
* Redeploy your local test using `--revert-strings debug` flag via the following commands and retest: `npm run deploy:core-debug && npm run deploy:hello-world-debug`
* Include the full stacktrace from your error as a .txt file attachment.
* Create a minimal repo that demonstrates the behavior (fork or otherwise)
* Steps require to reproduce issue (compile and cause the error)
* Holesky testing:
* Ensure contracts are verified on Holesky. Eg `forge verify-contract --chain-id 17000 --num-of-optimizations 200 src/YourContract.sol:YourContract YOUR_CONTRACT_ADDRESS`
* Send us your transaction hash where your contract is failing. We will use Tenderly to debug (adjust gas limit) and/or cast to re-run the transaction (eg `cast call --trace "trace_replayTransaction(0xTransactionHash)"`).- Local anvil testing:
- Recompile the contracts with the `--revert-strings debug` flag. Deploy the contracts again and retest.
- Include the full stacktrace from your error as a .txt file attachment.
- Create a minimal repo that demonstrates the behavior (fork or otherwise).
- Steps require to reproduce issue (compile and cause the error).
- Holesky testing:
- Ensure contracts are verified on Holesky. Eg `forge verify-contract --chain-id 17000 --num-of-optimizations 200 src/YourContract.sol:YourContract YOUR_CONTRACT_ADDRESS`
- Send us your transaction hash where your contract is failing. We will use Tenderly to debug (adjust gas limit) and/or cast to re-run the transaction (eg `cast call --trace "trace_replayTransaction(0xTransactionHash)"`).### Contact Us
If you're planning to build an AVS and would like to speak with a member of the EigenLayer DevRel team to discuss your ideas or architecture, please fill out this form and we'll be in touch shortly: [EigenLayer AVS Intro Call](https://share.hsforms.com/1BksFoaPjSk2l3pQ5J4EVCAein6l)
### Disclaimers
- This repo is meant currently intended for _local anvil development testing_. Holesky deployment support will be added shortly.
- Users who wish to build an AVS for Production purposes will want to migrate from the `ECDSAServiceManagerBase` implementation in `HelloWorldServiceManager.sol` to a BLS style architecture using [RegistryCoordinator](https://github.com/Layr-Labs/eigenlayer-middleware/blob/dev/docs/RegistryCoordinator.md).# Appendix (Future Capabilities In Progress)
## Adding a New Strategy
## Potential Enhancements to the AVS (for learning purposes)
The architecture can be further enhanced via:
- the nature of the request is more sophisticated than generating a constant string
- the operators might need to coordinate with each other
- the type of signature is different based on the constraints of the service
- the type and amount of security used to secure the AVS## Rust Operator instructions
### Automated deployment (uses existing state file)
1. Run `make start-chain-with-contracts-deployed`
- This will build the contracts, start an Anvil chain, deploy the contracts to it, and leaves the chain running in the current terminal2. Run `make start-rust-operator`
3. Run `make spam-rust-tasks`
Tests are supported in anvil only . Make sure to run the 1st command before running the tests:
```
cargo test --workspace
```## Existing Holesky Testnet Deployment
| Contract Name | Holesky Address |
| ------------- | ------------- |
| Hello World Service Manager | [0x3361953F4a9628672dCBcDb29e91735fb1985390](https://holesky.etherscan.io/address/0x3361953F4a9628672dCBcDb29e91735fb1985390) |Please see [Current Testnet Deployment](https://github.com/Layr-Labs/eigenlayer-contracts?tab=readme-ov-file#current-testnet-deployment) for additional deployed addresses.
You don't need to run a deployment script for holesky testnet, the contracts are already deployed.
1. Use the HOLESKY_ namespace env parameters in the code , instead of normal parameters.
2. Run `make start-rust-operator`
3. Run `make spam-rust-tasks`