Lightning Network Daemon
Find a file
Oliver Gugger 0e87863481
Merge pull request #9523 from ellemouton/graph9
graph/db: use View directly instead of manual DB tx creation and commit
2025-02-19 01:55:18 -06:00
.github multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
.vscode meta: add build tags to workspace settings for lsp support 2023-11-14 17:10:31 -08:00
aezeed multi: Fix typos and grammar in multiple docs 2024-07-22 20:08:12 -07:00
aliasmgr multi: update to fn v2 2024-12-04 13:19:00 -07:00
amp multi: fix make fmt 2022-08-23 22:10:24 +08:00
autopilot multi: fix linter by updating to latest version 2025-02-17 10:40:55 +01:00
batch batch: handle serialization errors correctly 2024-12-12 10:40:36 -08:00
blockcache blockcache: fix heap escape in GetBlock 2024-01-23 17:08:57 +08:00
brontide fix check node1Err !=nil but return a nil value error err 2024-12-19 14:57:28 +00:00
buffer lnwire: remove unused MaxMessagePayload const 2021-08-10 05:36:07 +08:00
build go.mod: update btclog dep 2025-01-10 18:23:28 +02:00
cert multi: replace ioutil.WriteFile 2024-04-25 11:23:31 +02:00
chainio chainio: add method CurrentHeight 2025-02-12 09:48:02 +08:00
chainntnfs Merge pull request #9378 from yyforyongyu/fix-unit-test 2025-01-13 03:13:02 -06:00
chainreg multi: update to fn v2 2024-12-04 13:19:00 -07:00
chanacceptor multi: rename nolint:lll to nolint:ll 2024-12-02 09:14:21 +02:00
chanbackup lnd+chanbackup: add lnd config flag 2025-01-24 10:56:15 +01:00
chanfitness multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
channeldb channeldb+routing: cache circuit and onion blob for htlc attempt 2025-02-10 11:28:23 +08:00
channelnotifier multi: remove kvdb.Tx from ChannelGraphSource.ForAllOutgoingChannels 2024-11-28 13:49:41 +02:00
clock multi: bump Go version 2023-09-05 10:11:42 -07:00
cluster multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
cmd lncli: only add additional info to specific cmds. 2025-02-12 23:29:56 +01:00
contractcourt refactor: replace math.Min and math.Max with built-in min/max 2025-02-06 09:46:40 +08:00
contrib docs: remove PIDFile from example systemd service 2022-01-11 14:08:18 +01:00
discovery graph+discovery: move funding tx validation to gossiper 2025-02-12 15:48:08 +02:00
docker multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
docs graph/db: unexport methods that take a transaction 2025-02-18 10:15:55 -03:00
feature htlcswitch+peer: allow the disabling of quiescence 2024-11-26 14:13:39 -07:00
fn fn/ContextGuard: use context.AfterFunc to wait 2025-01-02 10:38:26 -03:00
funding multi: update to fn v2 2024-12-04 13:19:00 -07:00
graph Merge pull request #9523 from ellemouton/graph9 2025-02-19 01:55:18 -06:00
healthcheck healthcheck: bump btclog dep 2024-10-26 14:16:25 +02:00
htlcswitch multi: introduce new traffic shaper method. 2025-01-29 09:59:02 +01:00
input input: export NUMS key parser. 2024-12-09 23:08:50 +01:00
internal/musig2v040 bug: fix json tag 2024-09-04 18:03:15 +08:00
invoices invoices: fix new linter error w/ Go 1.23 2025-02-13 17:09:28 -08:00
itest Merge pull request #9150 from yyforyongyu/fix-stuck-payment 2025-02-11 18:02:02 -08:00
keychain multi: bump btcd version. 2024-10-03 21:56:21 +02:00
kvdb gomod: remove replace of sqldb and kvdb 2024-12-19 19:02:46 +08:00
labels multi: fix make fmt 2022-08-23 22:10:24 +08:00
lncfg Merge pull request #8831 from bhandras/sql-invoice-migration 2025-01-23 05:48:25 -06:00
lnencrypt lnencrypt: add ECDHEncryptor 2024-01-09 12:32:38 +01:00
lnmock lnmock: let MockChain also implement lnwallet.BlockChainIO 2025-02-07 16:28:00 +02:00
lnpeer multi: extend lnpeer.Peer interface with Disconnect function 2024-08-27 14:11:06 -04:00
lnrpc Merge pull request #9518 from starius/bumpfee-immediate-doc-fix 2025-02-18 02:02:36 -06:00
lntest itest+lntest: assert payment is failed once the htlc times out 2025-02-10 11:31:51 +08:00
lntypes refactor: replace min/max helpers with built-in min/max 2025-02-06 09:45:10 +08:00
lnutils multi: optimize loggings around changes from blockbeat 2024-12-20 17:54:08 +08:00
lnwallet refactor: replace math.Min and math.Max with built-in min/max 2025-02-06 09:46:40 +08:00
lnwire lnwire_test: fix test doc string 2025-02-05 08:17:42 +02:00
macaroons lnwallet: populate resolution blob for incoming+outgoing HTLC resolutions 2024-11-14 16:09:57 -08:00
make multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
mobile mobile: correct output directory for generated files 2024-08-05 16:00:00 +02:00
monitoring multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
msgmux multi: update to fn v2 2024-12-04 13:19:00 -07: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 multi: move node ann validation code to netann pkg 2025-02-07 07:30:00 +02:00
peer multi: switch to lock time from sequence for coop close v2 2024-12-10 23:07:01 +01:00
peernotifier multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
pool multi: fix fmt.Errorf error wrapping 2024-02-27 11:13:40 +00:00
protofsm htlcswitch+go.mod: use updated fn.ContextGuard 2025-01-11 06:17:43 +02:00
queue remove repetitive words 2024-03-07 14:05:47 +08:00
record multi: rename nolint:lll to nolint:ll 2024-12-02 09:14:21 +02:00
routing multi: remove the need for the graphsession package 2025-02-18 10:15:41 -03:00
rpcperms multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
scripts Merge pull request #8831 from bhandras/sql-invoice-migration 2025-01-23 05:48:25 -06:00
shachain multi: fix make fmt 2022-08-23 22:10:24 +08:00
signal multi: start updating various loggers to use the new v2 type 2024-10-22 17:03:55 +02:00
sqldb refactor: replace math.Min and math.Max with built-in min/max 2025-02-06 09:46:40 +08:00
subscribe trivial: Fix spelling errors 2023-09-21 22:35:33 -04:00
sweep sweep: refactor storeRecord to updateRecord 2025-02-05 19:49:09 +08:00
ticker multi: bump Go version 2023-09-05 10:11:42 -07:00
tlv tlv: update to fn v2 2024-11-25 13:25:52 -07:00
tools multi: fix linter by updating to latest version 2025-02-17 10:40:55 +01:00
tor tor: update btclog dep 2024-10-26 14:18:32 +02:00
walletunlocker multi: wrap all errors 2024-04-11 15:04:03 +02:00
watchtower refactor: replace min/max helpers with built-in min/max 2025-02-06 09:45:10 +08:00
zpay32 multi: update to fn v2 2024-12-04 13:19:00 -07:00
.custom-gcl.yml tools+.: add custom linter configuration file 2024-12-02 09:14:21 +02:00
.editorconfig .editorconfig: add editor settings for most editors 2022-07-06 13:33:02 +02:00
.gitignore .golangci: Replace lll with custom ll 2024-12-02 09:23:06 +02:00
.golangci.yml multi: fix linter by updating to latest version 2025-02-17 10:40:55 +01:00
.protolint.yaml protolint: configure protolint and fix the protolinting issues 2024-01-22 22:00:00 +02:00
channel_notifier.go channeldb: let AddrsForNode indicate if the node was found or not 2024-11-28 13:36:15 +02:00
chanrestore.go multi: add new method ChainArbitrator.RedispatchBlockbeat 2024-12-20 17:54:07 +08:00
config.go lnd+chanbackup: add lnd config flag 2025-01-24 10:56:15 +01:00
config_builder.go channeldb+lnd: set invoice bucket tombstone after migration 2025-01-23 15:06:09 +01:00
config_test.go config_test.go: add test cases for supplyEnvValue 2024-03-14 17:55:59 +02:00
dev.Dockerfile multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
doc.go lnd: rename package main->lnd 2019-04-23 20:57:33 +02:00
Dockerfile multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
go.mod build: update go.mod to use Go 1.23 2025-02-13 16:57:06 -08:00
go.sum build: use the tagged 1.0.7 version of sqldb 2025-02-01 10:54:11 +01:00
intercepted_forward.go multi: update to fn v2 2024-12-04 13:19:00 -07:00
LICENSE multi: Update Licenses to 2022 [skip ci] 2022-02-09 00:25:20 +02:00
lnd.go lnd: use errors.Is for error comparison 2024-12-02 09:23:07 +02:00
log.go lnd: start blockbeatDispatcher and register consumers 2024-12-20 17:54:03 +08:00
logo.png README: add logo to top portion of page 2017-09-29 14:06:31 -07:00
Makefile multi: update build system to Go 1.23 2025-02-13 16:57:06 -08:00
pilot.go multi: remove kvdb.Tx from ChannelGraphSource.ForAllOutgoingChannels 2024-11-28 13:49:41 +02:00
README.md multi: Fix typos and grammar in multiple docs 2024-07-22 20:08:12 -07:00
rpcserver.go multi: remove the need for NewRoutingGraph 2025-02-18 07:59:57 -03:00
rpcserver_test.go multi: update to fn v2 2024-12-04 13:19:00 -07:00
sample-lnd.conf lnd+chanbackup: add lnd config flag 2025-01-24 10:56:15 +01:00
SECURITY.md lnd: add SECURITY.MD to bolster security entry in README 2022-10-17 12:05:15 -07:00
server.go multi: remove the need for the graphsession package 2025-02-18 10:15:41 -03:00
server_test.go multi: remove Litecoin config options 2023-10-06 16:34:47 -07:00
sqlc.yaml multi: add sqlc support 2023-07-10 17:36:58 -07:00
subrpcserver_config.go invoicesrpc: remove direct access to ChannelGraph pointer 2025-02-13 11:45:09 +02:00
sweeper_wallet.go lnd: skip canceling rebroadcast for neutrino backend 2023-04-26 10:38:13 +08:00
tls_manager.go multi: replace ioutil.WriteFile 2024-04-25 11:23:31 +02:00
tls_manager_test.go multi: replace ioutil.WriteFile 2024-04-25 11:23:31 +02:00
witness_beacon.go Merge pull request #9319 from thirdkeyword/master 2024-12-19 08:30:39 +01:00
witness_beacon_test.go lnd: replace defer cleanup with t.Cleanup 2022-10-13 17:47:04 +08:00

Lightning Network Daemon

Release build MIT licensed Irc Godoc Go Report Card

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 APIs 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