lnd version, "hacked" to enable seedless restore from xprv + scb
Go to file
Olaoluwa Osuntokun 306c4aef8e
autopilot: "Look ma no hands!", introducing autopilot mode
This commit introduces the initial implementation of the autopilot
mode. Autopilot is new mode within lnd that enables automatic channel
management. This means that if enabled lnd will attempt to
automatically manage channels according to a set of heuristic defined
within the main configuration for autopilot.Agent instance.

The autopilot.Agent implements a simple closed control loop. It takes
in external signals such as wallet balance updates, new open channel,
and channels that are now closed the updates its internal state. With
each external trigger it will consult the registered
AttachmentHeuristic to decide: if it needs to open any more channels,
and if so how much it should use to open the channels, ultimately
returning a set of recommended AttachmentDirectives. The
autopilot.Agent loop will then take those attempt to establish
connection, and go back in waiting for a new external signal.

With this first implementation the default heuristic is the
ConstrainedPrefAttachment implementation of AttachmentHeuristic. Given
a min and max channel size, a limit on the number of channels, and the
percentage of wallet funds to allocate to channels, it will attempt to
execute a heuristic drive by the Barabási–Albert model model in order
to attempt to drive the global graph towards a scale free topology.

This is commit implements a foundational layer for future simulations,
optimization, and additional heuristics.
2017-08-10 21:14:55 -07:00
autopilot autopilot: "Look ma no hands!", introducing autopilot mode 2017-08-10 21:14:55 -07:00
brontide brontide: add a test case to exercise all BOLT-0008 test vectors 2017-08-01 17:18:05 -07:00
chainntnfs chainntnfs/btcd+neutrino: close spendChan after send 2017-08-03 17:32:44 -07:00
channeldb fundingManager: persist state in opening process. 2017-08-10 13:14:25 -07:00
cmd/lncli rpc: force TLS for both grpc endpoint and grpc gateway 2017-08-03 18:21:22 -07:00
contrib contrib: add basic bash completion for lncli 2017-01-29 18:12:53 -08:00
discovery multi: add new method to generate fresh node announcments 2017-08-04 18:32:33 -07:00
docker docker: create distinct containers for blockchains 2017-07-05 10:41:31 -07:00
docs build: create parallel travis builds to isolate race condition tests 2017-07-04 16:05:22 -07:00
htlcswitch htlcswitch: sync mock server shutdown of switch 2017-08-10 16:14:01 -07:00
lnrpc lnrpc: add expiry field to the Hop proto within a Route 2017-08-02 21:13:51 -07:00
lnwallet multi: add new method to generate fresh node announcments 2017-08-04 18:32:33 -07:00
lnwire lnwire: add new error code for rejecting a channel that's too large 2017-08-07 16:31:22 -07:00
routing routing: update test to account for proper time locks 2017-08-02 21:07:35 -07:00
shachain multi: run all test instances in parallel 2017-06-17 01:00:07 +02:00
zpay32 multi: run all test instances in parallel 2017-06-17 01:00:07 +02:00
.gitignore git: add .DS_Store to .gitignore, remove obsolete entries 2017-05-04 17:39:15 -07:00
.travis.yml build: create parallel travis builds to isolate race condition tests 2017-07-04 16:05:22 -07:00
breacharbiter.go breacharbiter: sweep commitment output in case of unilateral close 2017-07-30 17:52:32 -07:00
chainregistry.go chains: specify a default CLTV expiration of 1 day equiv for each chain 2017-08-02 21:18:54 -07:00
config.go rpc: force TLS for both grpc endpoint and grpc gateway 2017-08-03 18:21:22 -07:00
doc.go add some daemon related skeleton files 2015-12-26 00:09:17 -06:00
features.go features: add a new feature bit for recent changes 2017-07-30 20:27:56 -07:00
fundingmanager_test.go fundingManager: persist state in opening process. 2017-08-10 13:14:25 -07:00
fundingmanager.go fundingmanager: removes NumPendingChannels 2017-08-10 16:14:01 -07:00
glide.lock build: update glide files to point to latest neutrino build 2017-08-02 21:22:08 -07:00
glide.yaml build: update glide files to point to latest neutrino build 2017-08-02 21:22:08 -07:00
gotest.sh build: create parallel travis builds to isolate race condition tests 2017-07-04 16:05:22 -07:00
invoiceregistry.go multi: replace usage of fastsha256 with crypto/sha256 2017-03-15 18:56:41 -07:00
LICENSE add copyright, license and discouragement in readme 2016-01-16 00:13:11 -08:00
lnd_test.go lnd_test: allow assertNumConnections to exit early 2017-08-10 16:14:01 -07:00
lnd.go lnd+rpcserver: use new public server API 2017-08-10 16:14:01 -07:00
log.go lnd: properly initialize LightningWallet with new config 2017-07-30 17:52:07 -07:00
networktest_test.go netharness: remove test for the node restart method 2016-11-16 12:46:45 -08:00
networktest.go multi: add new method to generate fresh node announcments 2017-08-04 18:32:33 -07:00
nodesigner.go nodesigner: make fully copy of key to avoid mutation 2017-08-04 18:27:21 -07:00
params.go config: add regtest support to lnd 2017-07-11 16:54:43 -07:00
peer_test.go plasma: rough draft of peer struct 2015-12-20 15:16:38 -06:00
peer.go peer: ensure goroutine launched during initial handshake exits 2017-08-10 18:07:54 -07:00
README.md Fixing badges in README 2017-03-22 11:44:29 -07:00
release.sh build: add release script 2017-01-12 18:30:47 -08:00
rpcserver.go rpcserver: lookup num pending channels from chanDB 2017-08-10 16:14:01 -07:00
server.go server: refactors w/ single mutex and sync disconnect 2017-08-10 16:14:01 -07:00
signal.go lnrpc+rpc+lnd: add new Stop command for gracefully shutting down lnd 2017-05-11 14:55:56 -07:00
utxonursery_test.go utxonursery: update serialization, API usage for recent SignDescriptor changes 2017-07-30 17:52:00 -07:00
utxonursery.go utxonursery: update serialization, API usage for recent SignDescriptor changes 2017-07-30 17:52:00 -07:00
version.go lnd: bump version to 0.2.1-alpha 2017-04-07 18:10:45 +02:00

Lightning Network Daemon

Build Status MIT licensed Irc Godoc Coverage Status

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