A highly modular Bitcoin Lightning library written in Rust. It's rust-lightning, not Rusty's Lightning!
Go to file
Matt Corallo 239d10ab2e
Merge pull request #3432 from tnull/2024-11-take-verifier-by-arc
Take circular `GossipVerifier` reference by `Arc`
2024-12-05 19:04:18 +00:00
.github/workflows ci: fixing the coverage report 2024-11-05 16:03:08 +01:00
bench Drop no-std feature 2024-09-18 09:07:58 +02:00
ci Allow manual_div_ceil 2024-12-05 00:48:35 -08:00
contrib Only attempt to rustfmt files checked into git 2024-09-18 18:04:54 +00:00
fuzz Merge pull request #3264 from jkczyz/2024-08-remove-user-provided-payer-id 2024-11-12 20:23:45 +00:00
lightning Merge pull request #3439 from valentinewallace/2024-12-remove-mpp-keysend-cfg 2024-12-05 15:31:14 +00:00
lightning-background-processor Merge pull request #3359 from TheBlueMatt/2024-10-less-types-re-export 2024-10-18 14:35:49 -07:00
lightning-block-sync Merge pull request #3432 from tnull/2024-11-take-verifier-by-arc 2024-12-05 19:04:18 +00:00
lightning-custom-message Drop lightning::ln::features::* type aliases 2024-10-13 13:52:56 +00:00
lightning-dns-resolver Set the dns_resolution feature in OMDomainResolver 2024-11-12 15:53:35 +00:00
lightning-invoice chore: make Bolt11InvoiceDescriptionRef copy 2024-12-05 16:46:51 +01:00
lightning-macros Add lightning-macros crate 2024-10-17 16:26:41 +02:00
lightning-net-tokio Drop lightning::ln::features::* type aliases 2024-10-13 13:52:56 +00:00
lightning-persister Stop using a constant for monitor update_ids after closure 2024-11-13 01:24:06 +00:00
lightning-rapid-gossip-sync Expand on RGS caching requirements 2024-11-23 11:33:16 -05:00
lightning-transaction-sync Update lightning-transaction-sync to use macros crate 2024-10-17 16:26:42 +02:00
lightning-types Add option_dual_fund feature 2024-11-20 14:01:42 +02:00
msrv-no-dev-deps-check Test lightning-transaction-sync in our no-dev-deps MSRV test 2024-09-08 21:21:35 +00:00
no-std-check Drop no-std feature 2024-09-18 09:07:58 +02:00
pending_changelog Remove UserConfig::accept_mpp_keysend 2024-12-04 15:57:20 -05:00
possiblyrandom Use native check-cfg lint in cargo beta 2024-07-12 11:48:15 +02:00
.editorconfig Introduce graph sync crate for fast-forwarding through gossip data downloaded from a server. 2022-05-25 01:21:33 -07:00
.gitignore Add a lightning-dns-resolver crate which answers bLIP 32 queries 2024-11-12 15:53:35 +00:00
ARCH.md arch: update diagram to reflect changes to KeysInterface 2024-10-08 10:35:14 -04:00
Cargo.toml Remove dual_funding cfg attributes 2024-11-18 15:18:39 +02:00
CHANGELOG.md Add CHANGELOG entry for 0.0.125 2024-10-14 19:37:03 +00:00
codecov.yml Ignore patch codecov as long as total coverage is within 1% of base 2021-03-19 20:49:14 -04:00
CONTRIBUTING.md Add a script to automatically rustfmt all required files 2024-08-05 17:57:19 +00:00
GLOSSARY.md Add a GLOSSARY.md 2021-01-18 11:05:57 -05:00
LICENSE-APACHE Relicense as dual Apache-2.0 + MIT 2020-08-10 21:12:44 -04:00
LICENSE-MIT Relicense as dual Apache-2.0 + MIT 2020-08-10 21:12:44 -04:00
LICENSE.md Relicense as dual Apache-2.0 + MIT 2020-08-10 21:12:44 -04:00
README.md Drop no-std feature 2024-09-18 09:07:58 +02:00
rustfmt_excluded_files rustfmt: Remove remaining lightning-invoice files from exclusion list 2024-11-14 13:51:44 +01:00
rustfmt.toml Add rustfmt to CI, ignore all files 2024-02-14 09:08:33 +01:00
SECURITY.md Remove ariard key from the security team 2023-05-28 20:58:06 +01:00

Rust-Lightning

Crate Documentation Safety Dance Security Audit

LDK/rust-lightning is a highly performant and flexible implementation of the Lightning Network protocol.

The primary crate, lightning, is runtime-agnostic. Data persistence, chain interactions, and networking can be provided by LDK's sample modules, or you may provide your own custom implementations. More information is available in the About section.

Status

The project implements all of the BOLT specifications, and has been in production use since 2021. As with any Lightning implementation, care and attention to detail is important for safe deployment.

Communications for rust-lightning and Lightning Development Kit happen through our LDK Discord channels.

Crates

  1. lightning The core of the LDK library, implements the Lightning protocol, channel state machine, and on-chain logic. Supports no_std and exposes only relatively low-level interfaces.
  2. lightning-background-processor Utilities to perform required background tasks for Rust Lightning.
  3. lightning-block-sync Utilities to fetch the chain data from a block source and feed them into Rust Lightning.
  4. lightning-invoice Data structures to parse and serialize BOLT #11 Lightning invoices.
  5. lightning-net-tokio Implementation of the rust-lightning network stack using the Tokio async runtime. For rust-lightning clients which wish to make direct connections to Lightning P2P nodes, this is a simple alternative to implementing the required network stack, especially for those already using Tokio.
  6. lightning-persister Implements utilities to manage rust-lightning channel data persistence and retrieval. Persisting channel data is crucial to avoiding loss of channel funds.
  7. lightning-rapid-gossip-sync Client for rapid gossip graph syncing, aimed primarily at mobile clients.

About

LDK/rust-lightning is a generic library that allows you to build a Lightning node without needing to worry about getting all of the Lightning state machine, routing, and on-chain punishment code (and other chain interactions) exactly correct. Note that LDK isn't, in itself, a node. For an out-of-the-box Lightning node based on LDK, see LDK-sample. However, if you want to integrate Lightning with custom features such as your own chain sync, key management, data storage/backup logic, etc., LDK is likely your best option. Some rust-lightning utilities such as those in chan_utils are also suitable for use in non-LN Bitcoin applications such as Discreet Log Contracts (DLCs) and bulletin boards.

Also check out LDK-node library if you want to easily integrate lightning in your application without taking care of all the boiler plate code.

In general, rust-lightning does not provide (but LDK has implementations of):

  • on-disk storage - you can store the channel state any way you want - whether Google Drive/iCloud, a local disk, any key-value store/database/a remote server, or any combination of them - we provide a clean API that provides objects which can be serialized into simple binary blobs, and stored in any way you wish.
  • blockchain data - we provide a simple block_connected/block_disconnected API which you provide block headers and transaction information to. We also provide an API for getting information about transactions we wish to be informed of, which is compatible with Electrum server requests/neutrino filtering/etc.
  • UTXO management - RL/LDK owns on-chain funds as long as they are claimable as part of a Lightning output which can be contested - once a channel is closed and all on-chain outputs are spendable only by the user, we provide users notifications that a UTXO is "theirs" again and it is up to them to spend it as they wish. Additionally, channel funding is accomplished with a generic API which notifies users of the output which needs to appear on-chain, which they can then create a transaction for. Once a transaction is created, we handle the rest. This is a large part of our API's goals - making it easier to integrate Lightning into existing on-chain wallets which have their own on-chain logic - without needing to move funds in and out of a separate Lightning wallet with on-chain transactions and a separate private key system.
  • networking - to enable a user to run a full Lightning node on an embedded machine, we don't specify exactly how to connect to another node at all! We provide a default implementation which uses TCP sockets, but, e.g., if you wanted to run your full Lightning node on a hardware wallet, you could, by piping the Lightning network messages over USB/serial and then sending them in a TCP socket from another machine.
  • private keys - again we have "default implementations", but users can choose to provide private keys to RL/LDK in any way they wish following a simple API. We even support a generic API for signing transactions, allowing users to run RL/LDK without any private keys in memory/putting private keys only on hardware wallets.

LDK's customizability was presented about at Advancing Bitcoin in February 2020: https://vimeo.com/showcase/8372504/video/412818125

Design Goal

The goal is to provide a fully-featured and incredibly flexible Lightning implementation, allowing users to decide how they wish to use it. With that in mind, everything should be exposed via simple, composable APIs. More information about rust-lightning's flexibility is provided in the About section above.

For security reasons, do not add new dependencies. Really do not add new non-optional/non-test/non-library dependencies. Really really do not add dependencies with dependencies. Do convince Andrew to cut down dependency usage in rust-bitcoin.

Rust-Lightning vs. LDK (Lightning Development Kit)

rust-lightning refers to the core lightning crate within this repo, whereas LDK encompasses rust-lightning and all of its sample modules and crates (e.g. the lightning-persister crate), language bindings, sample node implementation(s), and other tools built around using rust-lightning for Lightning integration or building a Lightning node.

Tagline

"Rust-Lightning, not Rusty's Lightning!"

Contributing

Contributors are warmly welcome, see CONTRIBUTING.md.

Project Architecture

For a rust-lightning high-level API introduction, see ARCH.md.

License is either Apache-2.0 or MIT, at the option of the user (ie dual-license Apache-2.0 and MIT).