Fiber Network Node (FNN) is a reference implementation of Fiber Network Protocol (FNP). In the current stage, it's not a production-ready implementation, but a prototype to demonstrate the feasibility of FNP. It's capable of:
- Establishing connections with other FNN
- Creating and closing fiber channel
- Payments over fiber channel (via fiber-scripts)
- Cross-chain asset transfer
Please note that the implementation is still under development, there are many limitations and known issues, you may find or report them in the issue tracker.
But as a prototype, it's a good starting point for developers to understand the FNP and try out the integration with their applications.
- Build the project, if you are using the released binary, you can skip this step:
cargo build --release
- Create a data folder for the node, then copy the built binary and testnet config file to it:
mkdir /folder-to/my-fnn
// if you are using the released binary, replace target/release/fnn with the path of released binary
cp target/release/fnn /folder-to/my-fnn
cp config/testnet/config.yml /folder-to/my-fnn
cd /folder-to/my-fnn
- FNN has the built-in wallet functionality to sign funding transactions, let's create or import a private key first. The private key is stored in the data folder and named
ckb/key
. You may use the ckb-cli to generate a new key or export an existing key:
mkdir ckb
ckb-cli account export --lock-arg <lock_arg> --extended-privkey-path ./ckb/exported-key
// ckb-cli exports master private key and chain code, FNN only needs the private key part
head -n 1 ./ckb/exported-key > ./ckb/key
- Start the node, by default it will output logs to the console, you may redirect it to a file:
RUST_LOG=info ./fnn -c config.yml -d .
The current state of the FNN is not stable, the protocol and storage format may changed between versions. We strongly recommend you to close the channel before upgrading the node, otherwise, you may lose the channel state:
-
list all channels and close them via RPC.
-
Stop the node and remove the storage of the node:
rm -rf /folder-to/my-fnn/fiber/store
- Repalce the fnn binary with the new version and start the node again.
If you want to keep the channel state, you may try to migrate the storage format manually:
-
Stop the node.
-
Backup the storage folder
/folder-to/my-fnn/fiber/store
. -
Run the fnn-migrate (it can be found in the release binary package) to migrate the storage format:
fnn-migrate -p /folder-to/my-fnn/fiber/store
- Repalce the fnn binary with the new version and start the node again.
- TODO: Add testnet deployed nodes information *