2016-10-18 16:37:32 +02:00
![Eclair Logo ](.readme/logo.png )
2016-01-21 15:39:56 +01:00
2017-03-17 19:08:24 +01:00
[![Build Status ](https://travis-ci.org/ACINQ/eclair.svg?branch=master )](https://travis-ci.org/ACINQ/eclair)
2017-03-17 19:07:29 +01:00
[![License ](https://img.shields.io/badge/license-Apache%202.0-blue.svg )](LICENSE)
2016-01-21 15:39:56 +01:00
2017-03-17 19:07:29 +01:00
**Eclair** (french for Lightning) is a scala implementation of the Lightning Network. It can run with or without a GUI, and a JSON-RPC API is also available.
2016-01-21 15:39:56 +01:00
2017-03-17 19:07:29 +01:00
This software follows the [Lightning Network Specifications (BOLTs) ](https://github.com/lightningnetwork/lightning-rfc ). Other implementations include [lightning-c], [lit], and [lnd].
2017-03-21 17:32:15 +01:00
---
2017-03-17 19:07:29 +01:00
:construction: Both the BOLTs and Eclair itself are a work in progress. Expect things to break/change!
2017-03-21 17:32:15 +01:00
:warning: Eclair currently only runs on regtest or testnet. We recommend testing in regtest, as it allows you to generate blocks manually and not wait for confirmations.
2016-10-18 16:23:31 +02:00
---
2017-03-17 19:07:29 +01:00
## Lightning Network Specification Compliance
2017-03-21 17:32:15 +01:00
[Eclair 0.2-alpha1 ](https://github.com/ACINQ/eclair/releases/tag/v0.2-alpha1 ) is compliant with the BOLTs at commit [06a5e6cbdbb4c6f8b8dab444de497cdb9c7d7f02 ](https://github.com/lightningnetwork/lightning-rfc/commit/06a5e6cbdbb4c6f8b8dab444de497cdb9c7d7f02 ), with the following caveats:
2016-01-21 15:39:56 +01:00
2017-03-17 19:07:29 +01:00
- [X] BOLT 1: Base Protocol
- [X] BOLT 2: Peer Protocol for Channel Management
- [X] BOLT 3: Bitcoin Transaction and Script Formats
- [X] BOLT 4: Onion Routing Protocol
- [X] BOLT 5: Recommendations for On-chain Transaction Handling
2017-03-21 17:32:15 +01:00
* If a revoked commitment tx is published, only the offender's main output will be stolen as punishment, not the HTLCs.
2017-03-17 19:07:29 +01:00
- [X] BOLT 7: P2P Node and Channel Discovery
- [X] BOLT 8: Encrypted and Authenticated Transport
- [X] BOLT 9: Assigned Feature Flags
2016-10-18 16:23:31 +02:00
2017-03-17 19:07:29 +01:00
## Overview
2016-10-18 16:23:31 +02:00
![Eclair Demo ](.readme/screen-1.png )
## Installation
2016-01-21 15:39:56 +01:00
2017-03-31 18:08:59 +02:00
:warning: **Those are valid for the most up-to-date, unreleased, version of eclair. Here are the [instructions for Eclair 0.2-alpha1](https://github.com/ACINQ/eclair/blob/v0.2-alpha1/README.md#installation)** .
2017-03-17 19:07:29 +01:00
### Configuring Bitcoin Core
2016-02-16 18:03:40 +01:00
2017-03-31 18:08:59 +02:00
Eclair needs a _synchronized_ , _segwit-ready_ , **_zeromq-enabled_** , _non-pruning_ , _tx-indexing_ [Bitcoin Core ](https://github.com/bitcoin/bitcoin ) node. This means that on Windows you will need Bitcoin Core 0.14.0.
2016-02-17 16:45:24 +01:00
2017-03-31 18:08:59 +02:00
Run bitcoind with the following minimal `bitcoin.conf` :
2016-11-14 17:19:29 +01:00
```
2017-03-21 17:32:15 +01:00
regtest=1
2016-10-18 16:23:31 +02:00
server=1
2017-03-17 19:07:29 +01:00
rpcuser=XXX
rpcpassword=XXX
txindex=1
2017-03-31 18:08:59 +02:00
zmqpubrawblock=tcp://127.0.0.1:29000
zmqpubrawtx=tcp://127.0.0.1:29000
2016-02-16 17:55:10 +01:00
```
2016-10-18 16:23:31 +02:00
2017-03-17 19:07:29 +01:00
### Installing Eclair
2016-10-18 16:23:31 +02:00
2017-03-17 19:07:29 +01:00
#### Windows
Just use the windows installer, it should create a shortcut on your desktop.
#### Linux, MacOs or manual install on Windows
2017-03-26 14:08:04 +02:00
You need to first install java, more precisely a JRE 1.8.
2017-03-17 19:07:29 +01:00
2017-03-27 11:14:54 +02:00
Then download the latest fat jar and run:
2016-10-18 16:23:31 +02:00
```shell
2017-03-17 19:07:29 +01:00
java -jar eclair-node_xxxxxx-fat.jar
2016-11-14 17:19:29 +01:00
```
2016-02-16 18:03:40 +01:00
2017-03-17 19:07:29 +01:00
### Configuring Eclair
2017-03-27 11:14:54 +02:00
#### Command-line parameters
2017-03-17 19:07:29 +01:00
2017-03-27 11:14:54 +02:00
option | description | default value
---------------|---------------------------------|--------------
--datadir | Path to the data directory | ~/.eclair
--headless | Run Eclair without the GUI |
--help, -h | Display usage text |
2016-02-16 17:55:10 +01:00
2017-03-21 17:32:15 +01:00
2017-03-27 11:14:54 +02:00
:warning: Using separate `datadir` is mandatory if you want to run **several instances of eclair** on the same machine. You will also have to change ports in the configuration (see below).
#### Configuration file
To change your node configuration, edit the file `eclair.conf` in `datadir` .
2017-03-17 19:07:29 +01:00
option | description | default value
-----------------------------|---------------------------|--------------
2016-10-18 16:23:31 +02:00
eclair.server.port | TCP port | 9735
2017-03-27 11:14:54 +02:00
eclair.api.port | HTTP port | 8080
2016-10-18 16:23:31 +02:00
eclair.bitcoind.rpcuser | Bitcoin Core RPC user | foo
eclair.bitcoind.rpcpassword | Bitcoin Core RPC password | bar
2017-03-31 18:08:59 +02:00
eclair.bitcoind.zmq | Bitcoin Core ZMQ address | tcp://127.0.0.1:29000
2016-10-18 16:23:31 +02:00
2016-10-18 16:37:32 +02:00
→ see [`application.conf` ](eclair-node/src/main/resources/application.conf ) for full reference.
2016-10-18 16:23:31 +02:00
2016-10-18 16:37:32 +02:00
## JSON-RPC API
2017-03-21 17:32:15 +01:00
method | params | description
-------------|-----------------------------------------------|-----------------------------------------------------------
connect | host, port, pubkey | connect to another lightning node through a secure connection
open | host, port, pubkey, fundingSatoshis, pushMsat | opens a channel with another lightning node
peers | | list existing local peers
channels | | list existing local channels
channel | channelId | retrieve detailed information about a given channel
network | | list all nodes that have been announced
genh | | generate a payment H
send | amountMsat, paymentHash, nodeId | send a payment to a lightning node
close | channelId | close a channel
close | channelId, scriptPubKey (optional) | close a channel and send the funds to the given scriptPubKey
help | | display available methods
2016-02-16 17:55:10 +01:00
2016-07-22 16:33:21 +02:00
## Resources
- [1] [The Bitcoin Lightning Network: Scalable Off-Chain Instant Payments ](https://lightning.network/lightning-network-paper.pdf ) by Joseph Poon and Thaddeus Dryja
- [2] [Reaching The Ground With Lightning ](https://github.com/ElementsProject/lightning/raw/master/doc/deployable-lightning.pdf ) by Rusty Russell
[Amiko-Pay]: https://github.com/cornwarecjp/amiko-pay
[lightning-c]: https://github.com/ElementsProject/lightning
[lnd]: https://github.com/LightningNetwork/lnd
2017-03-17 19:07:29 +01:00
[lit]: https://github.com/mit-dci/lit
2016-07-22 16:33:21 +02:00
[Thunder]: https://github.com/blockchain/thunder
2017-03-17 19:07:29 +01:00