lnd version, "hacked" to enable seedless restore from xprv + scb
Go to file
2017-01-10 12:23:56 -08:00
brontide brontide: modify key rotation to match test vectors in spec 2017-01-09 19:12:48 -08:00
chainntnfs chainntnfs: exit notifyBlockEpochs upon shutdown 2017-01-07 19:39:01 -08:00
channeldb channeldb: fix typo in AddChannelEdge 2017-01-09 19:02:37 -08:00
cmd/lncli cmd/lncli: add support for new "Perm" field in connectpeer command 2017-01-09 19:12:42 -08:00
docker docker: revamp docker set up to allow for an LN test cluster 2016-08-29 15:18:04 -07:00
docs docs: minor fixes 2017-01-09 19:37:49 -08:00
elkrem multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
lnrpc lnrpc: recompile protos 2017-01-09 19:01:10 -08:00
lnwallet lnwallet: add support for the push-during-funding workflow 2017-01-09 18:58:07 -08:00
lnwire lnwire: add new 'PushSatoshis' field to SingleFundingRequest 2017-01-09 17:24:32 -08:00
routing routing/testdata: ensure test channels have unique chan ID's 2017-01-09 19:47:52 -08:00
shachain multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
zpay32 zpay32: create new package for encoding/decoding payment requests 2017-01-02 15:17:58 -08:00
.gitignore Add RPC to show current total available channel capacity () 2016-09-15 12:00:56 -07:00
.travis.yml build: update travis to build against go 1.7.3 2016-10-26 14:28:51 -07:00
breacharbiter.go multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
config.go config+test: use default port for RPC server if one isn't specified 2017-01-05 13:18:26 -08:00
doc.go add some daemon related skeleton files 2015-12-26 00:09:17 -06:00
fundingmanager.go lnd: add support for pushing funds as part of channel funding 2017-01-09 19:05:36 -08:00
glide.lock build: update glide dependancies since roasbeef/btcsuite upstream merge 2017-01-05 14:08:43 -08:00
glide.yaml build: update glide dependancies since roasbeef/btcsuite upstream merge 2017-01-05 14:08:43 -08:00
htlcswitch.go peer+htlcswitch: add support for multi-hop HTLC error propagation 2017-01-07 21:22:17 -08:00
invoiceregistry.go multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
LICENSE add copyright, license and discouragement in readme 2016-01-16 00:13:11 -08:00
lnd_test.go test: add ability to push funds during funding to OpenChannel 2017-01-09 19:34:28 -08:00
lnd.go config+test: use default port for RPC server if one isn't specified 2017-01-05 13:18:26 -08:00
log.go lnd: fix lingering connmgr import 2017-01-05 14:08:36 -08:00
networktest_test.go netharness: remove test for the node restart method 2016-11-16 12:46:45 -08:00
networktest.go test: add ability to push funds during funding to OpenChannel 2017-01-09 19:34:28 -08:00
params.go lnd: remove support for the now obsolete SegNet4 2017-01-05 13:08:15 -08:00
peer_test.go plasma: rough draft of peer struct 2015-12-20 15:16:38 -06:00
peer.go lnd: add new "perm" bit to the ConnectPeer RPC call 2017-01-09 19:09:03 -08:00
README.md README: update readme to latest project state 2017-01-10 12:23:56 -08:00
rpcserver.go lnd: add new "perm" bit to the ConnectPeer RPC call 2017-01-09 19:09:03 -08:00
server.go lnd: add new "perm" bit to the ConnectPeer RPC call 2017-01-09 19:09:03 -08:00
signal.go create signal.go to handle SIGINT's 2016-03-22 18:42:01 -07:00
utxonursery_test.go multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
utxonursery.go utxonursery: add additional comments to new sections 2017-01-07 21:22:05 -08:00
version.go create version.go file 2016-03-22 18:40:54 -07:00

lnd - the Lightning Network Daemon

Build Status

lnd is a complete implementation of a node on the Lightning Network. lnd is currently deployed on the Bitcoin Test Network (testnet4) and utilizes an upcoming upgrade to Bitcoin: Segregated Witness. The project's codebase uses the btcsuite set of Bitcoin libraries, and is currently dependant on btcd.

The Lightning Network Daemon (lnd) is capable of: creating channels, closing channels, completely managing all channel states (including the exceptional ones!), maintaining a fully authenticated+validated channel graph, performing path finding within the network, passively forwarding incoming payments, and sending outgoing onion-encrypted payments through the network.

Lightning Network Specification Compliance

lnd doesn't yet fully conform to the Lightning Network specification (BOLT's). BOLT stands for: Basic of Lightning Technologies. The specifications are currently being drafted by several groups of implementers based around the world including the developers of lnd. The set of specification documents as well as our implementation of the specification are still a work-in-progress. With that said, lnd the current status of lnd's BOLT compliance is:

  • BOLT 1: Base Protocol
    • lnd currently utilizes a distinct wire format which was created before the emgergence of the current draft of BOLT specifications. We don't have an init message, but we do have analogues to all the other defined message types.
  • BOLT 2: Peer Protocol for Channel Management
    • lnd implements all the functionality defined within the document, however we currently use a different set of wire messages. Additionally, lnd uses a distinct commitment update state-machine and doesn't yet support dynamically updating commitment fees.
  • BOLT 3: Bitcoin Transaction and Script Formats
    • lnd currently uses a commitment design from a prior iteration of the protocol. Revocation secret generation is handled by elkrem and our scripts are slightly different.
  • BOLT 4: Onion Routing Protocol
  • BOLT 5: Recommendations for On-chain Transaction Handling
  • BOLT 7: P2P Node and Channel Discovery
  • BOLT 8: Encrypted and Authenticated Transport

Installation

  • In order to build form source, the following build dependencies are required:
    • Go 1.5 or 1.6

      Installation instructions can be found here: http://golang.org/doc/install. It is recommended to add $GOPATH/bin to your PATH at this point. Note: If you are building with Go 1.5, then you'll need to enable the vendor experiment by setting the GO15VENDOREXPERIMENT environment variable to 1. If you're using Go 1.6 or later, then it is safe to skip this step.

    • Glide

      This project uses Glide to manage dependencies as well as to provide reproducible builds. To install Glide, execute the following command (assumes you already have Go properly installed):

      $ go get -u github.com/Masterminds/glide

    • btcd

      This project currently requires btcd with segwit support, which is not yet merged into the master branch. Instead, roasbeef maintains a fork with his segwit implementation applied. To install, please see the installation instructions.

With the preliminary steps completed, to install lnd, lncli, and all related dependencies run the following commands:

$ git clone https://github.com/lightningnetwork/lnd $GOPATH/src/github.com/lightningnetwork/lnd
$ cd $GOPATH/src/github.com/lightningnetwork/lnd
$ glide install
$ go install . ./cmd/...

Updating

To update your version of lnd to the latest version run the following commands:

$ cd $GOPATH/src/github.com/lightningnetwork/lnd
$ git pull && glide install
$ go install . ./cmd/...

IRC

  • irc.freenode.net
  • channel #lnd
  • webchat

License

lnd is licensed under the MIT license.