lnd version, "hacked" to enable seedless restore from xprv + scb
Go to file
Olaoluwa Osuntokun 4a48b91e31
peer: update channel commitment updates to match spec
This commit modifies a peer’s htlcManager goroutine in order to
properly implement the new state machine defined by the specification.
The major change to this new state machine is that we can no longer
have a limited number of unrevoked commitment states. As a result, we
no longer need to track how many outsanding changes we have, and only
need to track if we have a pending change or not. This simplifies the
logic a bit.

Additionally, when receive a new signature we FIRST send an
RevokeAndAck, THEN we if we need to send a signature in response or
not. This is the major change to the state machine from the PoV of the
htlcManager. Previously, the order was flipped.
2017-02-21 01:43:21 -08:00
brontide multi: add link to LICENSE in README license badges (#100) 2017-01-12 16:31:08 -08:00
chainntnfs chainntnfs/btcdnotify: implement spend+epoch ntfn cancellations 2017-02-21 01:42:53 -08:00
channeldb channeldb: modify the NumUpdates field in ChannelDelta to be a uint64 2017-02-21 01:42:44 -08:00
cmd/lncli cmd/lncli: always consume first message for openchannel/closechannel 2017-02-07 19:36:24 -08:00
contrib contrib: add basic bash completion for lncli 2017-01-29 18:12:53 -08:00
docker Add chmod +x to start scripts in dockerfiles 2017-01-29 18:02:26 -08:00
docs multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
elkrem multi: update btcsuite API's to latest upstream changes 2017-01-05 13:56:34 -08:00
lnrpc lnrpc: add ping time to peer to the ListPeers response 2017-01-25 18:16:37 -08:00
lnwallet lnwallet: update channel state machine tests to latest changes 2017-02-21 01:43:18 -08:00
lnwire lnwire: directly embed the wire.OutPoint in all commitment update msgs 2017-02-21 01:42:35 -08:00
routing routing: fix compile error in definition due to chainntfns API change 2017-02-21 01:43:01 -08:00
shachain multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
zpay32 zpay32: fix decoding when payment request is too short 2017-02-16 19:30:28 +08:00
.gitignore Add RPC to show current total available channel capacity #29 (#35) 2016-09-15 12:00:56 -07:00
.travis.yml build: update travis to build against Go 1.8 and 1.7.5 2017-02-17 13:37:09 +08:00
breacharbiter.go multi: fix go vet warnings throughout code base 2017-02-16 19:33:19 +08:00
config.go multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
doc.go add some daemon related skeleton files 2015-12-26 00:09:17 -06:00
features.go lnwire+features: transition to the user friendly list of features 2017-02-21 01:25:05 -08:00
fundingmanager.go multi: update sub-systems to use latest iteration of wire messages 2017-02-21 01:42:37 -08:00
glide.lock cmd/lncli: add ability to render graph to 'describegraph' 2017-01-23 20:32:23 -08:00
glide.yaml cmd/lncli: add ability to render graph to 'describegraph' 2017-01-23 20:32:23 -08:00
htlcswitch.go htlcswitch: fix panic when receiving close req for unknown channel 2017-02-21 01:42:41 -08:00
invoiceregistry.go multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
LICENSE add copyright, license and discouragement in readme 2016-01-16 00:13:11 -08:00
lnd_test.go test: modify force close integration test to assert bob gets his balance 2017-02-07 20:54:11 -08:00
lnd.go lnd: don't attempt to serve the possible non-existent swagger file 2017-02-21 01:42:47 -08:00
log.go multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
networktest_test.go netharness: remove test for the node restart method 2016-11-16 12:46:45 -08:00
networktest.go multi: fix go vet warnings throughout code base 2017-02-16 19:33:19 +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 peer: update channel commitment updates to match spec 2017-02-21 01:43:21 -08:00
README.md multi: fix a variety of typos throughout the repo 2017-01-17 17:02:56 -08:00
release.sh build: add release script 2017-01-12 18:30:47 -08:00
rpcserver.go rpc: populate the payment route taken in resp to SendPaymentSync 2017-02-21 01:42:58 -08:00
server.go server: prevent panic when open channel by peerID fails 2017-02-21 01:42:56 -08:00
signal.go create signal.go to handle SIGINT's 2016-03-22 18:42:01 -07:00
utxonursery_test.go multi: fix go vet warnings throughout code base 2017-02-16 19:33:19 +08:00
utxonursery.go utxonursery: log txid when sending sweep transaction 2017-02-01 16:53:14 -08:00
version.go lnd: bump version to v0.1.1-alpha 2017-01-17 18:36:31 -08:00

Lightning Network Daemon

[Build Status] (https://travis-ci.org/lightningnetwork/lnd)      [MIT licensed] (https://github.com/lightningnetwork/lnd/blob/master/LICENSE)      [Irc] (https://webchat.freenode.net/?channels=lnd)      [Godoc] (https://godoc.org/github.com/lightningnetwork/lnd)

The Lightning Network Daemon (lnd) - is a complete implementation of a Lightning Network node and currently deployed on testnet4 - the Bitcoin Test Network. It utilizes an upcoming upgrade to Bitcoin: Segregated Witness (segwit). The project's codebase uses the btcsuite set of Bitcoin libraries, and is currently dependant on btcd. In the current state 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
  • 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 from source, the following build dependencies are required:

  • Go: Installation instructions can be found here.

    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/...

Tests

To check that lnd was installed properly run the following command:

go install; go test -v -p 1 $(go list ./... | grep -v  '/vendor/')

IRC

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

Further reading