Lightning is the open-source Rust implementation of Fleek Network.
This repository contains the source code for the implementation of Fleek Network.
Here is the directory schema:
lightning
├── lib
│ ├── affair
│ ├── atomo
│ ├── blake3-stream
│ ├── blake3-tree
│ ├── fleek-crypto
│ ├── hp-fixed
│ ├── ink-quill
│ ├── sdk
│ ├── sdk-macros
│ └── simulon
├── core
│ ├── application
│ ├── blockstore
│ ├── consensus
│ ├── handshake
│ ├── interfaces
│ ├── mock
│ ├── node
│ ├── notifier
│ ├── origin-arweave
│ ├── origin-filecoin
│ ├── origin-ipfs
│ ├── pod
│ ├── rep-collector
│ ├── reputation
│ ├── rpc
│ ├── signer
│ ├── table
│ ├── test-utils
│ └── topology
└── services
└── cdn
There are 3 top level directories lib
& core
and services
:
-
lib
: Any open source libraries we create to solve our own problems, these libraries are released with the friendly licenses with the Rust ecosystem (MIT
|Apache
). -
core
: This is all of the implementation of the core protocol, the main crate isnode
which contains our most important and releasedmain.rs
. Another important crate that is advised to everyone to get familiar with isinterfaces
which contains the top-down specification of all of the project. -
services
: Our services which we build using theSDK
.
The design pattern adopted for this software is highly inspired by the Object-Oriented model described by Alan Kay, which may be a bit different from OOP that grew to fame due to Java.
In a nutshell this is similar to the same idea, and we represent different units of computation and process as objects that communicate with each other by message passing.
To get the best of the ecosystem by default the nightly version of Rust is set in the rust-toolchain
file, the version in use is nightly-2023-07-01
, which is the version used by the rustfmt
project
itself which is a good sign of reliability.
This is set so that the default that the IDEs will pick and default invocation of cargo fmt
is consistent
between everyone and also we get to use some of the nightly options when it comes to clippy and fmt.
But this does not mean we're going to use this for building and releasing the binary, building the binary
for any actual use cases should use the cargo +stable build
command and the coming scripts and CI config
will ease this process. Our MSRV (Minimum Supported Rust Version) is 1.75.
So in summary: We use the default that is set in the rust-toolchain
to have consistent formatting of
the code. And does not necessarily indicate that it is the version of the compiler we are going to use
for builds, which should be rust stable and at a minimum version 1.75.
To run the node and perform a simple healthcheck, do the following:
# Start the node up
$ cargo run -r -- run
# In another terminal, send a request to the ping rpc endpoint
$ curl -X POST -H "Content-Type: application/json" -d '{
"jsonrpc": "2.0",
"method": "flk_ping",
"params": [],
"id": 1
}' https://127.0.0.1:4069/rpc/v0
# Response: {"jsonrpc":"2.0","result":"pong","id":1}
The project provides a nix flake for a determanistic development and build environment.
Nix (with flakes enabled) can be easily installed with https://github.com/DeterminateSystems/nix-installer
curl --proto '=https' --tlsv1.2 -sSf -L https://install.determinate.systems/nix | sh -s -- install
A development environment can be used with:
nix develop github:fleek-network/lightning
# For a local repo
nix develop .
The project can be built in a pure offline environment with:
nix build github:fleek-network/lightning
# For a local repo
nix build .
A shell can also be spawned with the lightning-node
binary provided in the path:
Note: until we provide a cachix cache from ci, the node will be built locally before entering the shell
nix shell github:fleek-network/lightning
# For a local repo
nix shell .
The binary can also be ran directly:
nix run github:fleek-network/lightning -- run -v
# For a local repo
nix run . -- run -v