選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。
 
 
 
 
ファイルへ移動
András Bánki-Horváth 6ac6ee0549
Merge pull request #725 from bhandras/swap-info-fixup
loop: fill the correct HTLC in loopout update
7日前
.github build: add postgres unit tests to makefile and CI 9ヶ月前
cmd cmd: add listinstantouts cmd 3週間前
docs Move DOCKER.md to docs directory 4ヶ月前
fsm fsm: add early abort observer option 1ヶ月前
instantout instantout: add listinstantout func 3週間前
labels sweepbatcher: add sweep batch 2ヶ月前
liquidity multi: use isExternalAddr flag 2ヶ月前
loopd swapclientserver: add listinstantouts 3週間前
loopdb loopdb: bump sqlc to 1.25.0 1週間前
looprpc looprpc: add listinstantouts 3週間前
regtest docker-regtest: fix loop-server config 3ヶ月前
scripts loopdb: bump sqlc to 1.25.0 1週間前
staticaddr version: static address protocol versions 2ヶ月前
swap swap: address family for static addresses 2ヶ月前
swapserverrpc swapserverrpc: add instantout quote req 2ヶ月前
sweep sweeper: fix formatting and update error 1年前
sweepbatcher loopout+sweepbatcher: calculate the per sweep onchain fees correctly 3週間前
test build: bump lnd dependency to v0.17.4-beta 2ヶ月前
tools multi: update linter, fix issues 6ヶ月前
utils utils: add MuSig2Sign function 2ヶ月前
.gitignore makefile+travis: add install and build commands 4年前
.golangci.yml multi: update linter, fix issues 6ヶ月前
Dockerfile build: add postgres unit tests to makefile and CI 9ヶ月前
LICENSE Update LICENSE 2年前
Makefile make: cache docker builds 3週間前
README.md Merge branch 'master' into patch-1 3年前
client.go loop: integrate sweepbatcher to loopout flow 2ヶ月前
client_test.go loop: fix loopout and client tests for sweeper integration 2ヶ月前
config.go loop: expose server grpc connection 2ヶ月前
executor.go loop: integrate sweepbatcher to loopout flow 2ヶ月前
go.mod build(deps): bump github.com/docker/docker 1週間前
go.sum build(deps): bump github.com/docker/docker 1週間前
interface.go multi: use isExternalAddr flag 2ヶ月前
log.go multi: add persistent logger 4年前
loopin.go loop: clean up server cost calculation for slightly better UX 3週間前
loopin_test.go unit: adjust for incorrect amount sweep 1ヶ月前
loopin_testcontext_test.go multi: move StoreMock to loopdb 2ヶ月前
loopout.go loop: fill the correct HTLC in loopout update 7日前
loopout_test.go loop: fix loopout and client tests for sweeper integration 2ヶ月前
release.sh build: add darwin-arm64 (Apple Silicon) as a release target 6ヶ月前
release_notes.md version: bump version to v0.27.0-beta 2ヶ月前
routing_plugin.go multi: bump btcec/v2 and btcutil to new versions 2年前
routing_plugin_test.go chore: fix typos 4ヶ月前
sample-loopd.conf conf: sample config for loopd 6ヶ月前
server_mock_test.go multi: move StoreMock to loopdb 2ヶ月前
sqlc.yaml tools: add sqlc generation tools 9ヶ月前
swap.go utils: add htlc & swap related helpers 2ヶ月前
swap_server_client.go loop: integrate sweepbatcher to loopout flow 2ヶ月前
testcontext_test.go loop: fix loopout and client tests for sweeper integration 2ヶ月前
uncharge_state.go loop: extract code from client package into new loop primary package 5年前
updates.go multi: consume and log sever state updates 4年前
utils.go multi: update linter, fix issues 6ヶ月前
version.go version: bump version to v0.28.0-beta 3週間前

README.md

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 ./...