Lightning Network Daemon
Go to file
positiveblue 5ff5225245
multi: break invoice depenency on channeldb
Now that we have the new package `lnd/channeldb/models` we can invert the
depenency between `channeldb` and `invoices`.

- Move all the invoice related types and errors to the
`invoices` package.

- Ensure that all the packages dealing with invoices use the types and
  interfaces defined in the `invoices` package.

- Implement the InvoiceDB interface (defined in `lnd/invoices`) in
  channeldb.

- Add new mock for InterfaceDB.

- `InvoiceRegistery` tests are now in its own subpacakge (they need to
  import both invoices & channeldb). This is temporary until we can
  decouple them.
2023-01-16 07:31:09 -08:00
.github GitHub: add job ID to cache key 2023-01-06 09:18:28 +01:00
.vscode .vscode: add editor settings for VS Code 2022-07-06 10:25:19 +02:00
aezeed scripted-diff: replace ⛰ emoji with $ [skip ci] 2022-10-28 12:06:49 -04:00
aliasmgr aliasmgr: cache peer alias in memory 2022-09-30 06:55:16 -07:00
amp multi: fix make fmt 2022-08-23 22:10:24 +08:00
autopilot autopilot: fix loop variables, use require 2022-10-13 14:40:43 +02:00
batch kvdb: move channeldb/kvdb to top level 2021-05-07 14:18:56 +02:00
blockcache blockcache: fix datarace in blockcache_test 2022-10-13 10:32:27 -04:00
brontide brontide,lnwire,wtwire,zpay32: appease linter 2022-11-11 08:44:30 -06:00
buffer lnwire: remove unused MaxMessagePayload const 2021-08-10 05:36:07 +08:00
build build: remove go-fuzz dependency and references 2022-11-11 10:44:37 -06:00
cert Fix typos in selfsigned.go [skip ci] 2023-01-15 15:13:29 -07:00
chainntnfs chainntnfs: move cache implementation to channeldb 2023-01-16 03:13:17 -08:00
chainreg chainntnfs: move cache implementation to channeldb 2023-01-16 03:13:17 -08:00
chanacceptor rpc: validate closing channel address in open channel requests 2023-01-04 04:42:39 -08:00
chanbackup chanbackup: replace defer cleanup with t.Cleanup 2022-10-13 17:01:35 +08:00
chanfitness fix typos [skip ci] 2022-04-11 18:26:54 +05:30
channeldb multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
channelnotifier multi: add logs when subservers are starting 2022-02-11 21:17:03 +08:00
clock clock: add missing package require and replace assert [skip ci] 2022-08-23 03:27:42 +08:00
cluster cluster: replace defer cleanup with t.Cleanup 2022-10-13 17:47:03 +08:00
cmd lncli+docs: skip gomnd check in switch statement 2023-01-16 09:55:07 +02:00
contractcourt multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
contrib docs: remove PIDFile from example systemd service 2022-01-11 14:08:18 +01:00
discovery discovery: properly set the isRemote field for validated networkMsg 2022-12-15 11:56:44 -08:00
docker scripted-diff: replace ⛰ emoji with $ [skip ci] 2022-10-28 12:06:49 -04:00
docs lncli+docs: skip gomnd check in switch statement 2023-01-16 09:55:07 +02:00
feature feature+lncfg: add config option to turn of anysegwit 2022-08-10 18:44:37 -07:00
fn fn: add new fn (func utils) package for generic helper funcs 2022-12-15 11:56:31 -08:00
funding funding: code style cleanup for the funding package 2023-01-12 22:40:51 +10:30
healthcheck fix typo liveliness 2022-11-25 21:52:00 +09:00
htlcswitch multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
input input: add tapscript full key only helper function 2022-08-25 09:20:24 +02:00
invoices multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
keychain mod+keychain+lntest: bump btcd to version with tweak fix 2022-11-11 10:20:08 +01:00
kvdb multi: fix make lint 2022-11-18 20:48:23 +08:00
labels multi: fix make fmt 2022-08-23 22:10:24 +08:00
lncfg multi: add custom message overrides to protocol config options 2023-01-05 12:05:05 -05:00
lnencrypt lnencrypt: Moves the crypto functions in the chanbackup package into its own package called lnencrypt 2022-09-30 01:53:45 -05:00
lnmock lnmock: add new package lnmock to host mocks 2023-01-12 22:08:02 +08:00
lnpeer multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
lnrpc multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
lntemp itest: add neutrinoclient to harnessnode 2023-01-12 13:24:44 +07:00
lntest Merge pull request #6783 from ErikEk/itest-neutrino-sub-server 2023-01-12 12:20:58 +01:00
lntypes lntypes+routing: add generic Min/Max functions 2022-12-12 13:22:28 +01:00
lnwallet multi: create channeldb/models package 2023-01-16 07:14:55 -08:00
lnwire lnwire: allow overriding of protocol messages outside of custom range 2023-01-05 12:05:04 -05:00
macaroons scripted-diff: replace ⛰ emoji with $ [skip ci] 2022-10-28 12:06:49 -04:00
make itest: increase test timeout to 120m 2022-11-17 21:06:12 +08:00
mobile docs: remove $ from multiline commands or frequently copied [skip ci] 2022-10-28 12:32:24 -05:00
monitoring Merge pull request #6224 from Roasbeef/prometheus-latency-histograms 2022-02-16 16:38:51 -08:00
multimutex multimutex: add hash mutex 2020-04-08 08:54:05 +02:00
nat multi: Fix typos [skip ci] 2022-01-24 12:19:02 +02:00
netann multi: fix make fmt 2022-08-23 22:10:24 +08:00
peer discovery+peer: add logs to reveal shutdown flow 2022-12-08 17:57:01 +08:00
peernotifier multi: add shutdown logs in subservers 2021-09-15 19:52:03 +08:00
pool pool: replace defer cleanup with t.Cleanup 2022-10-13 17:47:03 +08:00
queue queue: replace defer cleanup with t.Cleanup 2022-10-13 17:47:04 +08:00
record routing+channeldb: send payment metadata from invoice 2022-04-13 22:55:40 +02:00
routing routing: apply capacity factor 2022-12-12 13:22:29 +01:00
rpcperms multi: improve readability of goroutine defers 2022-11-21 13:54:24 +01:00
scripts make+scripts+docs: update fuzzing script and make fuzz 2022-11-11 10:30:05 -06:00
shachain multi: fix make fmt 2022-08-23 22:10:24 +08:00
signal multi: Update Licenses to 2022 [skip ci] 2022-02-09 00:25:20 +02:00
subscribe multi: add interface for subscribe client so it can be mocked 2020-09-08 13:47:13 +02:00
sweep multi: improve readability of goroutine defers 2022-11-21 13:54:24 +01:00
ticker multi: improve readability of goroutine defers 2022-11-21 13:54:24 +01:00
tlv multi: update to latest version of btcd in submodules 2022-11-16 17:50:34 -08:00
tools tools: fix docker version 2022-12-15 16:03:55 +08:00
tor multi: update to latest version of btcd in submodules 2022-11-16 17:50:34 -08:00
walletunlocker walletunlocker: re-create loader after unloading wallet 2022-12-09 11:09:05 +01:00
watchtower multi: improve readability of goroutine defers 2022-11-21 13:54:24 +01:00
zpay32 multi: fix make lint 2022-11-18 20:48:23 +08:00
.editorconfig .editorconfig: add editor settings for most editors 2022-07-06 13:33:02 +02:00
.gitignore build: remove go-fuzz dependency and references 2022-11-11 10:44:37 -06:00
.golangci.yml lnmock: add new package lnmock to host mocks 2023-01-12 22:08:02 +08:00
.travis.yml multi: bump Golang version to v1.19.2 2022-10-11 09:49:30 +02:00
channel_notifier.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
chanrestore.go channeldb: BigSize migration, store zero-conf, scid-alias bits 2022-07-07 17:10:27 -04:00
config_builder.go config_builder: use correct birthday when creating watch-only wallet 2022-10-18 13:29:09 +02:00
config.go multi: add custom message overrides to protocol config options 2023-01-05 12:05:05 -05:00
dev.Dockerfile docker: correct comment concerning lnd build/install 2022-11-22 11:54:24 +00:00
doc.go lnd: rename package main->lnd 2019-04-23 20:57:33 +02:00
Dockerfile multi: bump Golang version to v1.19.2 2022-10-11 09:49:30 +02:00
go.mod Merge pull request #7243 from guggero/ghost-utxo-fix 2022-12-13 20:00:31 -08:00
go.sum Merge pull request #7243 from guggero/ghost-utxo-fix 2022-12-13 20:00:31 -08:00
intercepted_forward.go contractcourt: add onchain interception 2022-04-13 11:31:33 +02:00
LICENSE multi: Update Licenses to 2022 [skip ci] 2022-02-09 00:25:20 +02:00
lnd.go fix typo 2022-10-27 16:26:47 -07:00
log.go multi: add sub-server dep 2022-04-30 08:55:49 +02:00
logo.png README: add logo to top portion of page 2017-09-29 14:06:31 -07:00
Makefile build: remove go-fuzz dependency and references 2022-11-11 10:44:37 -06:00
pilot.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
README.md trivial: link from readme to builder's guide 2021-09-10 05:42:26 +08:00
rpcserver_test.go Rpcserver: Add GetAllPermissions function for retrieving permissions for external macaroon baking 2021-10-01 16:51:16 -05:00
rpcserver.go multi: break invoice depenency on channeldb 2023-01-16 07:31:09 -08:00
sample-lnd.conf docs: Fix lnd.conf typo 2022-12-28 20:37:03 +10:30
SECURITY.md lnd: add SECURITY.MD to bolster security entry in README 2022-10-17 12:05:15 -07:00
server_test.go lnd: replace defer cleanup with t.Cleanup 2022-10-13 17:47:04 +08:00
server.go fix typo liveliness 2022-11-25 21:52:00 +09:00
subrpcserver_config.go chainrpc: add chainkit RPC service 2022-12-07 14:50:14 +00:00
witness_beacon_test.go lnd: replace defer cleanup with t.Cleanup 2022-10-13 17:47:04 +08:00
witness_beacon.go multi: create channeldb/models package 2023-01-16 07:14:55 -08:00

Lightning Network Daemon

Build Status MIT licensed Irc Godoc

The Lightning Network Daemon (lnd) - is a complete implementation of a Lightning Network node. lnd has several pluggable back-end chain services including btcd (a full-node), bitcoind, and neutrino (a new experimental light client). The project's codebase uses the btcsuite set of Bitcoin libraries, and also exports a large set of isolated re-usable Lightning Network related libraries within it. 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.
  • Updating advertised fee schedules.
  • Automatic channel management (autopilot).

Lightning Network Specification Compliance

lnd fully conforms to the Lightning Network specification (BOLTs). BOLT stands for: Basis of Lightning Technology. 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, the current status of lnd's BOLT compliance is:

  • BOLT 1: Base Protocol
  • BOLT 2: Peer Protocol for Channel Management
  • BOLT 3: Bitcoin Transaction and Script Formats
  • 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
  • BOLT 9: Assigned Feature Flags
  • BOLT 10: DNS Bootstrap and Assisted Node Location
  • BOLT 11: Invoice Protocol for Lightning Payments

Developer Resources

The daemon has been designed to be as developer friendly as possible in order to facilitate application development on top of lnd. Two primary RPC interfaces are exported: an HTTP REST API, and a gRPC service. The exported API's are not yet stable, so be warned: they may change drastically in the near future.

An automatically generated set of documentation for the RPC APIs can be found at api.lightning.community. A set of developer resources including guides, articles, example applications and community resources can be found at: docs.lightning.engineering.

Finally, we also have an active Slack where protocol developers, application developers, testers and users gather to discuss various aspects of lnd and also Lightning in general.

Installation

In order to build from source, please see the installation instructions.

Docker

To run lnd from Docker, please see the main Docker instructions

IRC

  • irc.libera.chat
  • channel #lnd
  • webchat

Safety

When operating a mainnet lnd node, please refer to our operational safety guidelines. It is important to note that lnd is still beta software and that ignoring these operational guidelines can lead to loss of funds.

Security

The developers of lnd take security very seriously. The disclosure of security vulnerabilities helps us secure the health of lnd, privacy of our users, and also the health of the Lightning Network as a whole. If you find any issues regarding security or privacy, please disclose the information responsibly by sending an email to security at lightning dot engineering, preferably encrypted using our designated PGP key (91FE464CD75101DA6B6BAB60555C6465E5BCB3AF) which can be found here.

Further reading