Lightning Network Daemon
Go to file
positiveblue 09d21345e1
multi: bump Go version
Bump all build go versions to v1.21.0
Bump the minimum build package version to v1.19.0

Debian "buster" is not longer supported. Security updates have been
discontinued since June 30th 2022. We will build using the latest
version, "bookworm".
2023-09-05 10:11:42 -07:00
.github build: bump Go version to v1.21.0, lnd version to v0.17.0 rc1 (#7914) 2023-08-23 17:33:11 -07:00
.vscode .vscode: add editor settings for VS Code 2022-07-06 10:25:19 +02:00
aezeed multi: add new build tag integration 2023-02-23 21:56:09 +08:00
aliasmgr multi: replace FundingLocked and funding_locked strings 2023-03-17 18:21:59 +08: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 multimutex: remove HashMutex, make Mutex type a type param 2023-06-01 17:39:49 -07:00
brontide brontide: derandomize fuzz tests 2023-05-23 08:32:13 -05:00
buffer lnwire: remove unused MaxMessagePayload const 2021-08-10 05:36:07 +08:00
build build: bump version to v0.17.0-rc2 (#7942) 2023-08-30 20:14:25 -07:00
cert multi: bump Go version 2023-09-05 10:11:42 -07:00
chainntnfs chainntnfs: remove block info from conf detail copy 2023-08-02 15:23:14 +02:00
chainreg multi: use fwding policy from models pkg 2023-08-22 06:22:33 +08:00
chanacceptor rpc: validate closing channel address in open channel requests 2023-01-04 04:42:39 -08:00
chanbackup multi: add new SCB version for the taproot chan type 2023-08-22 16:34:34 -07:00
chanfitness fix typos [skip ci] 2022-04-11 18:26:54 +05:30
channeldb docs: fix simple-taproot-channels typo [skip ci] (#7926) 2023-08-25 15:48:37 -07:00
channelnotifier channelnotifier: add InactiveLinkEvent 2023-01-18 03:46:16 +08:00
clock multi: bump Go version 2023-09-05 10:11:42 -07:00
cluster cluster: replace defer cleanup with t.Cleanup 2022-10-13 17:47:03 +08:00
cmd cmd/lncli: add new taproot channel type for openchannel 2023-08-22 16:32:33 -07:00
contractcourt contractcourt: fix potential panic during startup (#7936) 2023-08-29 10:27:09 -07:00
contrib docs: remove PIDFile from example systemd service 2022-01-11 14:08:18 +01:00
discovery funding+peer: add support for new musig2 channel funding flow 2023-08-22 16:32:07 -07:00
docker multi: bump Go version 2023-09-05 10:11:42 -07:00
docs multi: ensure link is always torn down due to db failures, add exponential back off for sql-kvdb failures (#7927) 2023-08-30 16:48:00 -07:00
feature feature: use +100 staging bit for taproot channels 2023-08-22 16:34:28 -07:00
funding multi: fix linter warnings with updated linter 2023-08-22 16:34:47 -07:00
healthcheck multi: bump Go version 2023-09-05 10:11:42 -07:00
htlcswitch multi: ensure link is always torn down due to db failures, add exponential back off for sql-kvdb failures (#7927) 2023-08-30 16:48:00 -07:00
input multi: fix linter warnings with updated linter 2023-08-22 16:34:47 -07:00
internal/musig2v040 internal/musig2: rename to musig2v040 to avoid confusion 2023-02-03 18:30:09 +01:00
invoices invoice/test: make all tests parallel 2023-07-24 10:54:03 -04:00
itest itest: unify PSBT channel funding tests, add taproot 2023-08-29 10:57:38 +02:00
keychain mod+keychain+lntest: bump btcd to version with tweak fix 2022-11-11 10:20:08 +01:00
kvdb multi: bump Go version 2023-09-05 10:11:42 -07:00
labels multi: fix make fmt 2022-08-23 22:10:24 +08:00
lncfg feature+lncfg: restore simple- prefix for taproot chans arg 2023-08-22 16:33:54 -07: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 multi: update channel db HTLC OnionBlob to array 2023-06-02 11:01:43 -04:00
lnpeer funding+peer: add support for new musig2 channel funding flow 2023-08-22 16:32:07 -07:00
lnrpc multi: bump Go version 2023-09-05 10:11:42 -07:00
lntest itest: unify PSBT channel funding tests, add taproot 2023-08-29 10:57:38 +02:00
lntypes lntypes+routing: add generic Min/Max functions 2022-12-12 13:22:28 +01:00
lnutils input: create new ScriptDesciptor interface 2023-08-22 16:33:44 -07:00
lnwallet multi: ensure link is always torn down due to db failures, add exponential back off for sql-kvdb failures (#7927) 2023-08-30 16:48:00 -07:00
lnwire multi: fix linter warnings with updated linter 2023-08-22 16:34:47 -07:00
macaroons macaroons: let ChangePassword re-encrypt all root keys 2023-05-17 14:44:15 +02:00
make multi: bump Go version 2023-09-05 10:11:42 -07:00
mobile make+docs: pull in modules patch 2023-03-31 10:15:21 -04:00
monitoring Merge pull request #6224 from Roasbeef/prometheus-latency-histograms 2022-02-16 16:38:51 -08:00
multimutex multimutex: remove HashMutex, make Mutex type a type param 2023-06-01 17:39:49 -07:00
nat multi: Fix typos [skip ci] 2022-01-24 12:19:02 +02:00
netann netann+docs: remove nil value from variadic list (#7922) 2023-08-24 11:47:42 -07:00
peer multi: ensure link is always torn down due to db failures, add exponential back off for sql-kvdb failures (#7927) 2023-08-30 16:48:00 -07: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 multi: bump Go version 2023-09-05 10:11:42 -07:00
record routing+channeldb: send payment metadata from invoice 2022-04-13 22:55:40 +02:00
routing multi: update lightning-onion version 2023-08-23 12:09:53 +02:00
rpcperms rpcserver: add debug log for rpc calls 2023-03-17 10:01:42 +08:00
scripts scripts: Direct 'lnd --help' output to a file 2023-08-08 11:47:21 +02: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
sqldb sqldb: add the sqldb package 2023-07-27 03:31:12 -07:00
subscribe multi: add interface for subscribe client so it can be mocked 2020-09-08 13:47:13 +02:00
sweep Merge pull request #7880 from yyforyongyu/fix-channel-arb 2023-08-15 16:25:54 +02:00
ticker multi: bump Go version 2023-09-05 10:11:42 -07:00
tlv multi: bump Go version 2023-09-05 10:11:42 -07:00
tools multi: bump Go version 2023-09-05 10:11:42 -07:00
tor multi: bump Go version 2023-09-05 10:11:42 -07:00
walletunlocker walletunlocker: fix unit test flake by closing DB 2023-02-06 14:08:08 +01:00
watchtower input+wallet: extract musig2 session management into new module 2023-08-22 16:30:39 -07:00
zpay32 lnwire: update Sig to support both ECDSA and schnorr sigs 2023-08-22 16:29:19 -07:00
.editorconfig .editorconfig: add editor settings for most editors 2022-07-06 13:33:02 +02:00
.gitignore multi: move itest out of lntest 2023-02-23 21:56:08 +08:00
.golangci.yml multi: bump Go version 2023-09-05 10:11:42 -07:00
.travis.yml build: bump Go version to v1.21.0, lnd version to v0.17.0 rc1 (#7914) 2023-08-23 17:33:11 -07:00
channel_notifier.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
chanrestore.go multi: add new SCB version for the taproot chan type 2023-08-22 16:34:34 -07:00
config_builder.go lnd: define additional rebroadcaster function. 2023-07-26 00:18:08 +02:00
config.go multi: add itest to check race between channel_ready and update_add_htlc 2023-08-09 01:29:19 +08:00
dev.Dockerfile build: bump Go version to v1.21.0, lnd version to v0.17.0 rc1 (#7914) 2023-08-23 17:33:11 -07:00
doc.go lnd: rename package main->lnd 2019-04-23 20:57:33 +02:00
Dockerfile multi: bump Go version 2023-09-05 10:11:42 -07:00
go.mod gomod: run go work sync to sync modules 2023-09-05 07:27:20 +08:00
go.sum gomod: run go work sync to sync modules 2023-09-05 07:27:20 +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 refactor: move State server REST registration 2023-08-08 11:43:25 +02:00
log.go lnd: fix orders when initializing subsystem loggers 2023-06-20 18:34:16 +08:00
logo.png README: add logo to top portion of page 2017-09-29 14:06:31 -07:00
Makefile Makefile: Calling the script check-sample-lnd-conf.sh 2023-08-03 18:04:25 +02: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 feature: use +100 staging bit for taproot channels 2023-08-22 16:34:28 -07:00
sample-lnd.conf multi: fix linter warnings with updated linter 2023-08-22 16:34:47 -07:00
SECURITY.md lnd: add SECURITY.MD to bolster security entry in README 2022-10-17 12:05:15 -07:00
server_test.go multi: add new build tag integration 2023-02-23 21:56:09 +08:00
server.go feature+lncfg: add new CLI flag to opt into taproot chans 2023-08-22 16:32:35 -07:00
sqlc.yaml multi: add sqlc support 2023-07-10 17:36:58 -07:00
subrpcserver_config.go multi: update node announcement features in feature manager first 2023-05-04 10:35:46 -04:00
sweeper_wallet.go lnd: skip canceling rebroadcast for neutrino backend 2023-04-26 10:38:13 +08:00
tls_manager_test.go tlsmanager: fix autocert autogeneration 2023-07-11 21:24:46 +02:00
tls_manager.go tlsmanager: fix autocert autogeneration 2023-07-11 21:24:46 +02:00
witness_beacon_test.go lnd: replace defer cleanup with t.Cleanup 2022-10-13 17:47:04 +08:00
witness_beacon.go lnd+contractcourt: add more debug logs 2023-04-19 01:18:19 +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