A scala implementation of the Lightning Network. Eclair is french for Lightning.
More precisely, this is an implementation of Rusty's deployable lightning. In particular it uses the same wire protocol, and almost the same state machine.
The general idea is to have an actor per channel, everything being non-blocking.
A "blockchain watcher" is responsible for monitoring the blockchain, and sending events (eg. when the anchor is spent).
- lightning-types: scala code generation using protobuf's compiler (wire protocol)
- eclair-demo: actual implementation
Run Demo.scala
to have an example of:
- Opening a channel
- Updating the balance with an HTLC
- Closing the channel
- Network
- Routing
- Channel state machine
- HTLC Scripts
- Unilateral close handling
- Relaying Payment
- Blockchain watcher
- Storing states in a database
- [1] Lightning Network by Joseph Poon and Thaddeus Dryja (website), github repository (golang)
- [2] Deployable Lightning by Rusty Russel (Blockstream), github repository (C)
- [3] Thunder Network by Mats Jerratsch (Blockchain.info), github repository (Java)