Core Lightning — Lightning Network implementation focusing on spec compliance and performance
Go to file
Rusty Russell 36e018161f wire: generate marshal/unmarshal from spec.
Including tests!

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2016-12-01 13:50:02 +10:30
bitcoin Remove trailing whitespace from source. 2016-11-11 09:32:04 +10:30
ccan ccan: update. 2016-11-09 18:55:15 +10:30
contrib contrib/lightning-pay: helper to make a payment. 2016-10-19 12:02:27 +10:30
daemon lightningd: don't listen at all if no port number set. 2016-11-18 17:13:29 +10:30
doc doc: manpages for the various lightning RPC calls. 2016-09-06 16:47:41 +09:30
secp256k1 libsecp256k1: update. 2016-07-01 12:00:17 +09:30
test Remove trailing whitespace from source. 2016-11-11 09:32:04 +10:30
wire wire: generate marshal/unmarshal from spec. 2016-12-01 13:50:02 +10:30
.gitignore check-bolt: check that comments in code match the specs. 2016-05-03 11:27:56 +09:30
.gitmodules daemon/jsmn: Add submodule for jsmn. 2016-01-22 06:37:13 +10:30
.travis.yml travis-ci: Added travis-ci config 2016-11-11 14:25:41 +01:00
check-bolt.c Remove trailing whitespace from source. 2016-11-11 09:32:04 +10:30
close_tx.c permute_tx: don't save permutation map. 2016-08-18 14:23:46 +09:30
close_tx.h base58, script, protobuf_convert: don't use temporary secp256k1 context. 2016-07-01 12:00:17 +09:30
find_p2sh_out.c scripteq: simple helper for comparing scripts. 2016-05-03 11:27:56 +09:30
find_p2sh_out.h Remove unused script functions now we use witness. 2016-04-24 20:09:39 +09:30
HACKING.md controlled_time: remove 2016-11-09 18:54:15 +10:30
INSTALL.md Merge remote-tracking branch 'origin/pr/42' 2016-10-17 12:15:36 +10:30
irc.c Merge remote-tracking branch 'origin/pr/44' 2016-10-17 12:31:19 +10:30
irc.h Merge remote-tracking branch 'origin/pr/44' 2016-10-17 12:31:19 +10:30
LICENSE licensing: Make license explicit. 2016-01-22 06:41:46 +10:30
lightning.pb-c.c pkt_init: check feature bits. 2016-10-07 17:39:55 +10:30
lightning.pb-c.h pkt_init: check feature bits. 2016-10-07 17:39:55 +10:30
lightning.proto pkt_init: check feature bits. 2016-10-07 17:39:55 +10:30
Makefile wire: generate marshal/unmarshal from spec. 2016-12-01 13:50:02 +10:30
opt_bits.c opt_bits: parsing routines for 'bits' == 100 satoshi. 2015-06-07 13:52:04 +09:30
opt_bits.h header cleanup: sort include lines into alpha order, after config.h 2016-01-22 06:38:08 +10:30
overflows.h daemon: routing infrastructure. 2016-07-01 12:00:17 +09:30
permute_tx.c permute_tx: don't save permutation map. 2016-08-18 14:23:46 +09:30
permute_tx.h permute_tx: don't save permutation map. 2016-08-18 14:23:46 +09:30
protobuf_convert.c Remove trailing whitespace from source. 2016-11-11 09:32:04 +10:30
protobuf_convert.h protobuf_convert: expose helpers for unwrapping protobufs into tal heirarchies 2016-08-30 20:15:57 +09:30
README.md README.md: add "upgrade" instructions and add port config for public nodes. 2016-11-21 10:21:41 +10:30
remove_dust.h channel: remove htlcs array. 2016-08-18 14:23:46 +09:30
TODO.md TODO: remove to-dones. 2016-09-06 16:47:48 +09:30
utils.c routing: Added IRC announcement glue 2016-09-07 23:49:39 +02:00
utils.h opt, utils: new arg for wrappers due to low-level tal change. 2016-11-09 18:56:38 +10:30
version.c getinfo: add version information 2016-09-14 05:28:51 +09:30
version.h getinfo: add version information 2016-09-14 05:28:51 +09:30

Lightning Protocol Reference Implementation

In this repository we're developing a reference implementation of bitcoin lightning (see: http://lightning.network which proposed the original "lightning network").

This implementation is being developed in parallel with the protocol definition, which you can find on my fork of the protocol description repository.

If you're interested in using the daemon to test payments, the JSON-RPC interface is documented in the following manual pages:

Steps:

  1. If you're running a previous version, you'll need to shut it down (maybe close channels first) and delete the $HOME/.lightning directory.
  2. Install and compile the requirements.
  3. Make sure bitcoind is running in testnet mode, and has the latest blocks.
  4. Get some test bitcoins, such as from TPs' testnet faucet.
  5. If you want others to connect to your lightningd, create $HOME/.lightning/config and put port=8334 in it (or any other port).
  6. Run daemon/lightningd.
  7. Run daemon/lightning-cli getinfo to check it's working.
  8. Find a node using daemon/lightning-cli getnodes (this will populate over time).
  9. Create a new connection to the node using contrib/lightning-open-channel ADDRESS PORT AMOUNT where AMOUNT is in BTC (.04294967 is the maximum possible). If successful, this will return only once a block has been mined with the funding transaction in it.
  10. You can create more channels if you wish.
  11. You can accept payment using daemon/lightning-cli invoice MILLISATOSHI LABEL; it will give you a payment hash to give to the payer.
  12. You can send payments using contrib/lightning-pay DEST-ID MILLISATOSHI PAYMENT-HASH.

Final note: This is very much a testbed and work in progress; expect All The Things to change, all the time.

Welcome aboard!

Rusty.