mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-02-21 00:08:28 +00:00
88 lines
2.8 KiB
Markdown
88 lines
2.8 KiB
Markdown
# Nimbus Light Portal Network Client
|
|
|
|
[data:image/s3,"s3://crabby-images/add19/add19b990ae11ceff9ee8eaf5a9ea7cdb3723fb7" alt="fluffy CI"](https://github.com/status-im/nimbus-eth1/actions/workflows/fluffy.yml)
|
|
data:image/s3,"s3://crabby-images/0b711/0b711680a4a39ab794fb1b7a0e4b33d1b7df9604" alt="Stability: experimental"
|
|
[data:image/s3,"s3://crabby-images/95a73/95a734eb40ed1b81f456bc8cbf5d611cc1bf9cff" alt="License: Apache"](https://opensource.org/licenses/Apache-2.0)
|
|
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="License: MIT"](https://opensource.org/licenses/MIT)
|
|
|
|
[data:image/s3,"s3://crabby-images/a892e/a892e7b4ad2b389233d90c7addb5aee039412557" alt="Discord: Nimbus"](https://discord.gg/XRxWahP)
|
|
[data:image/s3,"s3://crabby-images/7c66d/7c66d7b0717195a3036608c1f625f3c2a05f3a55" alt="Status: #nimbus-general"](https://join.status.im/nimbus-general)
|
|
|
|
## Introduction
|
|
This folder holds the development of the Nimbus client implementation supporting
|
|
the Portal Network. The Portal Network is a project still heavily in research
|
|
phase and fully in flux. This client is thus still highly experimental.
|
|
|
|
Current status of specifications can be found in the
|
|
[stateless-ethereum-specs repository](https://github.com/ethereum/stateless-ethereum-specs/blob/master/portal-network.md).
|
|
|
|
|
|
## Development Updates
|
|
|
|
To keep up to date with changes and development progress, follow the
|
|
[Nimbus blog](https://our.status.im/tag/nimbus/).
|
|
|
|
## How to Build & Run
|
|
|
|
### Prerequisites
|
|
- GNU Make, Bash and the usual POSIX utilities. Git 2.9.4 or newer.
|
|
|
|
### Build fluffy client
|
|
```bash
|
|
git clone git@github.com:status-im/nimbus-eth1.git
|
|
cd nimbus-eth1
|
|
make fluffy
|
|
|
|
# See available command line options
|
|
./build/fluffy --help
|
|
|
|
# Example command: Run the client and connect to a bootnode.
|
|
./build/fluffy --log-level:debug --bootnode:enr:<base64 encoding of ENR>
|
|
```
|
|
|
|
### Update and rebuild fluffy client
|
|
```bash
|
|
# From the nimbus-eth1 repository
|
|
git pull
|
|
# To bring the git submodules up to date
|
|
make update
|
|
|
|
make fluffy
|
|
```
|
|
|
|
### Windows support
|
|
|
|
Follow the steps outlined [here](../README.md#windows) to build fluffy on Windows.
|
|
|
|
|
|
## For Developers
|
|
|
|
When working on this repository, you can run the `env.sh` script to run a
|
|
command with the right environment variables set. This means the vendored
|
|
Nim and Nim modules will be used, just as when you use `make`.
|
|
|
|
E.g.:
|
|
|
|
```bash
|
|
# start a new interactive shell with the right env vars set
|
|
./env.sh bash
|
|
```
|
|
|
|
More [development tips](../README.md#devel-tips)
|
|
can be found on the general nimbus-eth1 readme.
|
|
|
|
The code follows the
|
|
[Status Nim Style Guide](https://status-im.github.io/nim-style-guide/).
|
|
|
|
## License
|
|
|
|
Licensed and distributed under either of
|
|
|
|
* MIT license: [LICENSE-MIT](../LICENSE-MIT) or http://opensource.org/licenses/MIT
|
|
|
|
or
|
|
|
|
* Apache License, Version 2.0, ([LICENSE-APACHEv2](../LICENSE-APACHEv2) or http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
at your option. These files may not be copied, modified, or distributed except according to those terms.
|