a7218e84ea
This commit prevents the case where btcd stops before lnd is fully started, thus making lnd_test hang on trying to stop lnd using `StopDaemon`. The underlying issue is that while lnd is trying to start the server and subscribe to block notifications from btcd, btcd stops, and lnd continues to attempt to reconnect before it ever starts the interrupt handler. This reversal avoids that issue by making sure lnd is stopped before btcd. |
||
---|---|---|
autopilot | ||
brontide | ||
chainntnfs | ||
channeldb | ||
cmd/lncli | ||
contrib | ||
discovery | ||
docker | ||
docs | ||
htlcswitch | ||
lnrpc | ||
lnwallet | ||
lnwire | ||
macaroons | ||
routing | ||
shachain | ||
zpay32 | ||
.gitignore | ||
.travis.yml | ||
breacharbiter.go | ||
chainregistry.go | ||
config.go | ||
doc.go | ||
features.go | ||
fundingmanager_test.go | ||
fundingmanager.go | ||
glide.lock | ||
glide.yaml | ||
gotest.sh | ||
invoiceregistry.go | ||
LICENSE | ||
lnd_test.go | ||
lnd.go | ||
log.go | ||
mock.go | ||
networktest_test.go | ||
networktest.go | ||
nodesigner.go | ||
params.go | ||
peer_test.go | ||
peer.go | ||
pilot.go | ||
README.md | ||
release.sh | ||
rpcserver.go | ||
server.go | ||
signal.go | ||
test_utils.go | ||
utxonursery_test.go | ||
utxonursery.go | ||
version.go |
Lightning Network Daemon
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
(BOLTs). 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 aninit
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 byelkrem
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, please see the installation instructions.
IRC
- irc.freenode.net
- channel #lnd
- webchat