2
0
mirror of https://github.com/lightninglabs/loop synced 2024-11-04 06:00:21 +00:00
Go to file
Alex Bosworth 91fe0c1b71
Merge pull request #842 from lightninglabs/alexbosworth-patch-7
version: bump version to v0.28.9-beta
2024-10-30 11:55:05 -07:00
.github github: bump go version 2024-05-23 10:13:21 +02:00
cmd cmd: add fetchl402 cli command 2024-10-30 17:18:35 +01:00
docs Move DOCKER.md to docs directory 2023-12-12 22:15:29 +02:00
fsm fsm: add ctx to SendEvent and Actions 2024-10-21 21:17:56 +02:00
instantout Merge pull request #839 from sputn1ck/fsm_ctx 2024-10-22 16:49:45 +02:00
labels sweepbatcher: add sweep batch 2024-01-23 20:38:09 +02:00
liquidity chore: fix some comments for struct field 2024-07-19 14:20:07 +08:00
loopd looprpc: add FetchL402 rpc 2024-10-30 17:18:34 +01:00
loopdb multi: do not rename swapserverrpc to looprpc 2024-09-10 09:54:17 -03:00
looprpc looprpc: add FetchL402 rpc 2024-10-30 17:18:34 +01:00
notifications ntfn: use l402 store for tokens 2024-10-30 17:12:28 +01:00
regtest regtest: fix loopserver address 2024-05-20 10:11:04 +02:00
scripts loopdb: bump sqlc to 1.25.0 2024-03-20 13:57:11 +01:00
staticaddr multi: do not rename swapserverrpc to looprpc 2024-09-10 09:54:17 -03:00
swap swap: fix leaf estimation in AddSuccessToEstimator 2024-08-12 12:18:36 -03:00
swapserverrpc swapserverrpc: refactor reservation notifications 2024-10-07 11:57:31 +02:00
sweep sweep: fix godoc of GetSweepFeeDetails 2024-07-18 13:38:57 -03:00
sweepbatcher sweepbatcher: make sure feerate does not decrease 2024-10-15 11:28:40 -03:00
test multi: bump lnd compile time dependency to v0.18.4-beta 2024-10-22 09:12:31 +02:00
tools multi: bump lnd compile time dependency to v0.18.4-beta 2024-10-22 09:12:31 +02:00
utils multi: bump lnd compile time dependency to v0.18.4-beta 2024-10-22 09:12:31 +02:00
.gitignore makefile+travis: add install and build commands 2020-04-15 09:19:06 +02:00
.golangci.yml multi: update linter, fix issues 2023-10-03 19:36:40 +02:00
client_test.go client: fill LastHop in FetchSwaps 2024-08-08 10:00:36 -03:00
client.go client: fill LastHop in FetchSwaps 2024-08-08 10:00:36 -03:00
config.go multi: replace LSAT with L402 2024-04-24 13:28:28 -03:00
cost_migration_test.go loopd: allow setting RPC batch size when running cost migration 2024-09-20 10:13:48 +02:00
cost_migration.go loopd: allow setting RPC batch size when running cost migration 2024-09-20 10:13:48 +02:00
Dockerfile build: fix dockerfile 2024-06-03 18:03:14 +02:00
executor.go loop: integrate sweepbatcher to loopout flow 2024-01-23 20:38:10 +02:00
go.mod build(deps): bump github.com/opencontainers/runc from 1.1.12 to 1.1.14 2024-10-22 07:25:23 +00:00
go.sum build(deps): bump github.com/opencontainers/runc from 1.1.12 to 1.1.14 2024-10-22 07:25:23 +00:00
interface.go chore: fix some comments for struct field 2024-07-13 13:50:12 +08:00
LICENSE Update LICENSE 2022-01-30 12:07:04 +00:00
log.go multi: add persistent logger 2019-10-28 17:09:23 +01:00
loopin_test.go unit: adjust for incorrect amount sweep 2024-02-13 15:03:04 +01:00
loopin_testcontext_test.go multi: move StoreMock to loopdb 2024-01-23 20:38:06 +02:00
loopin.go utils: refactor SelectHopHints to use narrower interface 2024-06-14 12:37:58 +02:00
loopout_test.go multi: bump lnd compile time dependency to v0.18.4-beta 2024-10-22 09:12:31 +02:00
loopout.go loopout: correctly account for the prepay amount when calculating costs 2024-06-03 14:54:18 +02:00
Makefile make: cache docker builds 2024-03-07 17:05:22 +01:00
README.md Merge branch 'master' into patch-1 2021-03-24 20:36:24 -10:00
release_notes.md version: bump version to v0.28.2-beta 2024-05-24 13:34:58 -07:00
release.sh build: add darwin-arm64 (Apple Silicon) as a release target 2023-09-28 19:09:57 +00:00
routing_plugin_test.go chore: fix typos 2023-12-03 13:20:44 +08:00
routing_plugin.go chore: fix some comments 2024-06-05 15:12:47 +08:00
sample-loopd.conf multi: replace LSAT with L402 2024-04-24 13:28:28 -03:00
server_mock_test.go loop: add migration for loopout swaps to fix negative stored costs 2024-06-03 14:54:18 +02:00
sqlc.yaml tools: add sqlc generation tools 2023-06-20 14:19:31 +02:00
swap_server_client.go multi: do not rename swapserverrpc to looprpc 2024-09-10 09:54:17 -03:00
swap.go utils: add htlc & swap related helpers 2024-01-23 20:38:08 +02:00
testcontext_test.go client: fill LastHop in FetchSwaps 2024-08-08 10:00:36 -03:00
uncharge_state.go loop: extract code from client package into new loop primary package 2019-03-06 20:34:01 -08:00
updates.go multi: consume and log sever state updates 2020-07-16 21:02:06 +02:00
utils.go utils: refactor SelectHopHints to use narrower interface 2024-06-14 12:37:58 +02:00
version.go version: bump version to v0.28.9-beta 2024-10-30 10:54:40 -07:00

Lightning Loop

Lightning Loop is a non-custodial service offered by Lightning Labs that makes it easy to move bitcoin into and out of the Lightning Network.

Features

  • Automated channel balancing
  • Privacy-forward non-custodial swaps
  • Opportunistic transaction batching to save on fees
  • Progress monitoring of in-flight swaps

Use Cases

  • Automate channel balancing with AutoLoop (Learn more)
  • Deposit to a Bitcoin address without closing channels with Loop In
  • Convert outbound liquidity into inbound liquidity with Loop Out
  • Refill depleted Lightning channels with Loop In

Installation

Download the latest binaries from the releases page.

Execution

The Loop client needs its own short-lived daemon to facilitate swaps. To start loopd:

loopd

To use Loop in testnet, simply pass the network flag:

loopd --network=testnet

By default loopd attempts to connect to the lnd instance running on localhost:10009 and reads the macaroon and tls certificate from ~/.lnd. This can be altered using command line flags. See loopd --help.

Usage

AutoLoop

AutoLoop makes it easy to keep your channels balanced. Checkout our autoloop documentation for details.

Loop Out

Use Loop Out to move bitcoins on Lightning into an on-chain Bitcoin address.

To execute a Loop Out:

loop out <amt_in_satoshis>

Other notable options:

  • Use the --fast flag to swap immediately (Note: This opts-out of fee savings made possible by transaction batching)
  • Use the --channel flag to loop out on specific channels
  • Use the --addr flag to specify the address the looped out funds should be sent to (Note: By default funds are sent to the lnd wallet)

Run loop monitor to monitor the status of a swap.

Loop In

Use Loop In to convert on-chain bitcoin into spendable Lightning funds.

To execute a Loop In:

loop in <amt_in_satoshis>

More info

For more information about using Loop checkout our Loop FAQs.

Development

Regtest

To get started with local development against a stripped down dummy Loop server running in a local regtest Bitcoin network, take a look at the regtest server environment example documentation.

Testnet

To use Loop in testnet, simply pass the network flag:

loopd --network=testnet

Submit feature requests

The GitHub issue tracker can be used to request specific improvements or report bugs.

Join us on Slack

Join us on the LND Slack and join the #loop channel to ask questions and interact with the community.

LND

Note that Loop requires lnd to be built with all of its subservers. Download the latest official release binary or build lnd from source by following the installation instructions. If you choose to build lnd from source, use the following command to enable all the relevant subservers:

make install tags="signrpc walletrpc chainrpc invoicesrpc"

API

The Loop daemon exposes a gRPC API (defaults to port 11010) and a REST API (defaults to port 8081).

The gRPC and REST connections of loopd are encrypted with TLS and secured with macaroon authentication the same way lnd is.

If no custom loop directory is set then the TLS certificate is stored in ~/.loop/<network>/tls.cert and the base macaroon in ~/.loop/<network>/loop.macaroon.

The loop command will pick up these file automatically on mainnet if no custom loop directory is used. For other networks it should be sufficient to add the --network flag to tell the CLI in what sub directory to look for the files.

For more information on macaroons, see the macaroon documentation of lnd.

NOTE: Loop's macaroons are independent from lnd's. The same macaroon cannot be used for both loopd and lnd.

Build from source

If youd prefer to build from source:

git clone https://github.com/lightninglabs/loop.git
cd loop/cmd
go install ./...