2017-05-09 15:33:42 +02:00
# c-lightning: A specification compliant Lightning Network implementation in C
2015-06-24 08:48:07 +02:00
2017-05-09 15:33:42 +02:00
c-lightning is a [standard compliant ](https://github.com/lightningnetwork/lightning-rfc ) implementation of the Lightning Network protocol.
2018-01-18 04:22:56 +01:00
The Lightning Network is a scalability solution for Bitcoin, enabling secure and instant transfer of funds between any two parties for any amount.
2015-06-24 08:48:07 +02:00
2017-05-09 15:33:42 +02:00
For more information about the Lightning Network please refer to http://lightning.network.
## Project Status
2018-01-18 04:22:56 +01:00
This implementation is still very much a work in progress. It can be used for testing, but __it should not be used for real funds__ .
We do our best to identify and fix problems, and implement missing features.
2017-05-09 15:33:42 +02:00
Any help testing the implementation, reporting bugs, or helping with outstanding issues is very welcome.
2017-08-29 07:15:39 +02:00
Don't hesitate to reach out to us on IRC at [#lightning-dev @ freenode.net ](http://webchat.freenode.net/?channels=%23lightning-dev ), [#c-lightning @ freenode.net ](http://webchat.freenode.net/?channels=%23c-lightning ), or on the mailing list [lightning-dev@lists.linuxfoundation.org ](https://lists.linuxfoundation.org/mailman/listinfo/lightning-dev ).
2017-05-09 15:33:42 +02:00
## Getting Started
2017-12-04 06:50:39 +01:00
c-lightning currently only works on Linux (and possibly Mac OS with some tweaking), and requires a locally running `bitcoind` (version 0.15 or above) that is fully caught up with the network you're testing on.
2017-05-09 15:33:42 +02:00
### Installation
2017-08-29 07:15:39 +02:00
Please refer to the [installation documentation ](doc/INSTALL.md ) for detailed instructions.
2017-05-09 15:33:42 +02:00
For the impatient here's the gist of it for Ubuntu and Debian:
```
2018-01-18 17:25:29 +01:00
sudo apt-get install -y autoconf automake build-essential git libtool libgmp-dev libsqlite3-dev python python3 net-tools
2017-05-09 15:33:42 +02:00
git clone https://github.com/ElementsProject/lightning.git
cd lightning
make
```
Or if you like to throw `docker` into the mix:
```
sudo docker run \
-v $HOME/.lightning:/root/.lightning \
-v $HOME/.bitcoin:/root/.bitcoin \
-p 9735:9735 \
2017-11-04 00:46:51 +01:00
cdecker/lightningd:latest
2017-05-09 15:33:42 +02:00
```
### Starting `lightningd`
In order to start `lightningd` you will need to have a local `bitcoind` node running in either testnet or regtest mode:
```
bitcoind -daemon -testnet
```
2017-12-10 13:41:10 +01:00
Wait until `bitcoind` has synchronized with the testnet network. In case you use regtest, make sure you generate at least 432 blocks to activate SegWit.
2017-08-22 15:55:28 +02:00
2018-01-04 01:59:14 +01:00
Make sure that you do not have `walletbroadcast=0` in your
2018-01-26 13:18:23 +01:00
`~/.bitcoin/bitcoin.conf` , or you may run into trouble. Notice that
currently pruned nodes are not supported and may result in
`lightningd` being unable to synchronize with the blockchain.
2018-01-04 01:59:14 +01:00
2017-08-22 15:55:28 +02:00
You can start `lightningd` with the following command:
2017-05-09 15:33:42 +02:00
```
2017-08-22 15:55:28 +02:00
lightningd/lightningd --network=testnet --log-level=debug
2017-05-09 15:33:42 +02:00
```
2018-01-19 11:09:54 +01:00
### Listing all commands:
2018-01-21 00:41:39 +01:00
`cli/lightning-cli help` will print a table of the API and lists the following commands
2018-01-19 11:09:54 +01:00
2017-05-09 15:33:42 +02:00
### Opening a channel on the Bitcoin testnet
First you need to transfer some funds to `lightningd` so that it can open a channel:
```
# Returns an address <address>
2017-12-10 13:41:10 +01:00
cli/lightning-cli newaddr
2017-05-09 15:33:42 +02:00
# Returns a transaction id <txid>
bitcoin-cli -testnet sendtoaddress < address > < amount >
2018-01-13 00:18:43 +01:00
```
2017-05-09 15:33:42 +02:00
2018-01-13 00:18:43 +01:00
`lightningd` will register the funds once the transaction is
confirmed.
2017-05-09 15:33:42 +02:00
2018-01-13 00:18:43 +01:00
If you don't have any testcoins you can get a few from a faucet
such as [TPs' testnet faucet ](http://tpfaucet.appspot.com/ ) or
[Kiwi's testnet faucet ](https://testnet.manu.backend.hamburg/faucet ).
You can send it directly to the `lightningd` address.
Confirm `lightningd` got funds by:
2017-05-09 15:33:42 +02:00
2018-01-13 00:18:43 +01:00
```
# Returns an array of on-chain funds.
cli/lightning-cli listfunds
```
2017-05-09 15:33:42 +02:00
2018-01-13 00:18:43 +01:00
Once `lightningd` has funds, we can connect to a node and open a
channel.
Let's assume the **remote** node is accepting connections at
`<ip>` (and optional `<port>` , if not 9735) and has the node ID
`<node_id>` :
2017-05-09 15:33:42 +02:00
```
2017-12-04 10:12:22 +01:00
cli/lightning-cli connect < node_id > < ip > [< port > ]
2017-08-28 18:04:01 +02:00
cli/lightning-cli fundchannel < node_id > < amount >
2017-05-09 15:33:42 +02:00
```
This opens a connection and, on top of that connection, then opens a channel.
2018-01-04 00:51:21 +01:00
The funding transaction needs 1 confirmations in order for the channel to be usable, and 6 to be broadcast for others to use.
2018-01-21 10:40:17 +01:00
You can check the status of the channel using `cli/lightning-cli listpeers` , which after 1 confirmation should say that `state` is `CHANNELD_NORMAL` ; after 6 confirmations you can use `cli/lightning-cli listchannels` to verify that the `public` field is now `true` .
2018-01-28 17:04:28 +01:00
### Different states
States starting with `ONCHAIND` mean that the channel has been closed and an onchain transaction exists reflecting the resulting balances
* `ONCHAIND_OUR_UNILATERAL` > Closed by you without cooperation of the counterparty
* `ONCHAIND_THEIR_UNILATERAL` > Closed by the counterparty without your cooperation
* `ONCHAIND_MUTUAL` > Negotiated closing by both sides
States starting with `CHANNELD` mean that funds are not available onchain, and from that moment they can only be moved offchain, this is, through the Lightning Network
* `CHANNELD_AWAITING_LOCKIN` > Waiting for confirmation of the channel funding transaction
* `CHANNELD_NORMAL` > Channel is active
The `GOSSIPING` state means that you are connected to a peer but there is no payment channel yet.
2017-05-09 15:33:42 +02:00
2018-01-20 13:13:23 +01:00
### Sending and receiving payments
2017-05-09 15:33:42 +02:00
Payments in Lightning are invoice based.
2018-01-13 12:14:36 +01:00
The recipient creates an invoice with the expected `<amount>` in millisatoshi (or `"any"` for a donation), a unique `<label>` and a `<description>` the payer will see:
2017-05-09 15:33:42 +02:00
```
2017-11-13 11:03:12 +01:00
cli/lightning-cli invoice < amount > < label > < description >
2017-05-09 15:33:42 +02:00
```
2018-01-17 08:58:04 +01:00
This returns some internal details, and a standard invoice string called `bolt11` (named after the [BOLT #11 lightning spec ](https://github.com/lightningnetwork/lightning-rfc/blob/master/11-payment-encoding.md )).
2017-05-09 15:33:42 +02:00
2018-01-13 12:14:36 +01:00
The sender can feed this `bolt11` string to the `decodepay` command to see what it is, and pay it simply using the `pay` command:
2017-05-09 15:33:42 +02:00
```
2018-01-13 12:14:36 +01:00
cli/lightning-cli pay < bolt11 >
2017-05-09 15:33:42 +02:00
```
2018-01-13 12:14:36 +01:00
Note that there are lower-level interfaces (and more options to these interfaces) for more sophisticated use.
2017-05-09 15:33:42 +02:00
## Further information
2016-03-15 07:38:38 +01:00
2016-09-06 09:17:41 +02:00
JSON-RPC interface is documented in the following manual pages:
2017-05-09 15:33:42 +02:00
2016-09-06 09:17:41 +02:00
* [invoice ](doc/lightning-invoice.7.txt )
2018-01-21 20:35:37 +01:00
* [listinvoices ](doc/lightning-listinvoices.7.txt )
2016-09-06 09:17:41 +02:00
* [waitinvoice ](doc/lightning-waitinvoice.7.txt )
2017-12-13 14:39:15 +01:00
* [waitanyinvoice ](doc/lightning-waitanyinvoice.7.txt )
2016-09-06 09:17:41 +02:00
* [delinvoice ](doc/lightning-delinvoice.7.txt )
* [getroute ](doc/lightning-getroute.7.txt )
* [sendpay ](doc/lightning-sendpay.7.txt )
2018-01-21 20:35:37 +01:00
* [pay ](doc/lightning-pay.7.txt )
* [listpayments ](doc/lightning-listpayments.7.txt )
* [decodepay ](doc/lightning-decodepay.7.txt )
2015-07-03 06:33:45 +02:00
2017-08-28 18:04:01 +02:00
For simple access to the JSON-RPC interface you can use the `cli/lightning-cli` tool, or the [python API client ](contrib/pylightning ).