Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: add fedimint lightning gateway case study #288

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added docs/.vuepress/public/img/fedimint.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
---
title: "Fedimint Lightning Gateway uses LDK Node to simplify deployment and liquidity management"
description: "Learn how Fedimint uses LDK node to simplify deployment and liquidity management in the lightning gateway"
date: "2024-12-16"
authors:
- Justin Moeller
tags:
- Case-Studies
---

The [Fedimint Lightning Gateway](https://github.com/fedimint/fedimint/blob/master/docs/gateway.md) is a server application that powers the Lightning payments for Fedimints. Lightning Gateways enable Fedimint ecash users access to the broader Lightning network by offering a trustless ecash to Lightning swap service to the federation. A Fedimint user incentivizes the gateway to pay a Lightning invoice on its behalf by locking ecash to a hash time locked contract that is enforced by the federation. The gateway can then claim the locked ecash by revealing the preimage from the paid invoice. To receive ecash, the gateway will fund a Fedimint client as long as it receives a preimage in return that the gateway can use to claim a payment on the Lightning network. If this sounds similar to how HTLCs in Lightning work, that's because it is! However, there is the added caveat that Lightning Gateways must also manage an ecash balance alongside the Lightning channels.

Lightning Gateways can also be connected to more than one federation. This allows the gateway to provide Lightning services to many Fedimints at once and also short-circuit the Lightning network altogether if the payment is between connected federations (or within the same federation). The Lightning Gateway must hold a balance for each federation it services payments for, so that it can fund incoming payments. Conceptually, this is similar to a "virtual channel" between the Lightning Gateway and the target federation. The ecash balance that the gateway holds for each federation is analogous to inbound liquidity in Lightning.

![Fedimint Lightning Gateway](../assets/gatewayd-arch.png)

Previously, gateway operators had the option of connecting their gateway to either a Core Lightning or LND node. While this deployment configuration is convenient for node runners who have existing liquidity, this comes with additional technical burden and operational difficulties for new gateways. Gateway operators need to deploy and operate two separate daemons (e.g `LND` and `gatewayd`) and monitor liquidity for their channels and connected federations in each. It is our goal to make it as easy as possible to use Fedimint, so to reduce these operational complexities, it made sense to integrate LDK node directly into the Lightning Gateway to provide a seamless ecash and Lightning experience.

# What we did
We chose to use LDK Node because of the ease of use for getting started. LDK Node has numerous pre-set defaults that make deploying a Lightning node easy, such as an integrated BDK wallet and a SQLite database. Because we already supported LND and CLN, we had done work previously to abstract away the interface to the Lightning node. This made the implementation of LDK Node into the Lightning Gateway straightforward - only a handful of functions needed to be implemented.

However, in order for the Lightning Gateway to receive a Lightning payment on behalf of a Fedimint user in a trustless manner, we needed the ability to create invoices where LDK Node does not know the preimage (i.e a HOLD invoice). This was not originally supported in LDK Node. LDK Node intentionally has a slim API, but after discussing our use case with the LDK team, the API was exposed.

![LDK Node Lightning Gateway](../assets/gatewayd-arch-ldk2.png)

Integrating LDK Node into the Lightning Gateway also exposed new challenges. Previously, for Lightning management operations such as opening and closing channels, we relied on the operator interacting directly with the underlying Lightning node. With LDK Node integrated into the gateway, the gateway operator no longer has another daemon to fall back to for channel or UTXO management; it must be done within the gateway itself. Most of the work we did was simply exposing Lightning operations and debugging logs to the gateway operator.

With ecash and Lightning management available in a single daemon, we are looking to explore automated methods of managing liquidity, such as the [LSPv1 spec](https://github.com/lightning/blips/blob/master/blip-0051.md). We believe that ecash presents an opportunity to make liquidity management more efficient and are hoping to build this directly into the gateway itself.

# Results
The LDK Gateway will be available to use as a Lightning node in the v0.5 Fedimint release and will be able to service new federations starting with v0.6. We hope to see new node operators deploy `gatewayd` and take advantage of the integrated Lightning node for simpler deployment and liquidity management. Feedback is always welcome, [please join our discord channel](https://discord.gg/cEVEmqCgWG) to get in touch with the developers or submit an issue on our [Github](https://github.com/fedimint/fedimint).

Shoutout to tnull, tvolk131, joschican, and elsirion for reviewing drafts of this document and their work on the LDK Gateway.
Binary file added docs/assets/fedimint.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/assets/gatewayd-arch-ldk2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/assets/gatewayd-arch.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
17 changes: 16 additions & 1 deletion docs/case-studies.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,11 @@ features:
image: "/img/bitkit.svg"
imageAlt: ""
caseStudyLink: "/blog/bitkit-uses-ldk-to-build-the-ultimate-alternative-to-custodial-wallets/"
- title: "Fedimint"
details: "Manage federated ecash and a lightning node all in one application"
image: "/img/fedimint.png"
imageAlt: ""
caseStudyLink: "/blog/fedimint-lightning-gateway-uses-ldk-node-to-simplify-deployment-and-liquidity-management/"
editLink: false
lastUpdated: false
---
Expand Down Expand Up @@ -127,6 +132,11 @@ lastUpdated: false
<h3><a href="https://cequals.xyz/" target="_blank">c=</a></h3>
<p>Tools and services that connect people to the Lightning Network</p>
</div>
<div class="case-study-item">
<a href="https://fedimint.org/" target="_blank"><img src="./assets/fedimint.png" /></a>
<h3><a href="https://fedimint.org/" target="_blank">Fedimint</a></h3>
<p>Server application for managing federated ecash and a self-custodial lightning node</p>
</div>
<div class="case-study-item">
<a href="https://github.com/kuutamolabs/lightning-knd" target="_blank"><img src="./assets/kuutamo.png" /></a>
<h3><a href="https://github.com/kuutamolabs/lightning-knd" target="_blank">kuutamo</a></h3>
Expand Down Expand Up @@ -166,7 +176,7 @@ lastUpdated: false
<a href="https://voltage.cloud/" target="_blank"><img src="./assets/voltage.png" /></a>
<h3><a href="https://voltage.cloud/" target="_blank">Voltage</a></h3>
<p>Enterprise-grade infrastructure for the Lightning Network</p>
</div>
</div>
</div>

</template>
Expand Down Expand Up @@ -249,6 +259,11 @@ lastUpdated: false
<h3><a href="https://github.com/EttaWallet/EttaWallet" target="_blank">EttaWallet</a></h3>
<p>A simple open-source wallet with a strong bias toward usability, accessibility, and UX</p>
</div>
<div class="case-study-item">
<a href="https://fedimint.org/" target="_blank"><img src="./assets/fedimint.png" /></a>
<h3><a href="https://fedimint.org/" target="_blank">Fedimint</a></h3>
<p>Server application for managing federated ecash and a self-custodial lightning node</p>
</div>
<div class="case-study-item">
<a href="https://github.com/fiksn/gossiper" target="_blank"><img src="./assets/github.png" /></a>
<h3><a href="https://github.com/fiksn/gossiper" target="_blank">Gossiper</a></h3>
Expand Down
Loading