commit
3112fc30d8
|
@ -156,8 +156,9 @@ AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
|
||||||
PERSISTENCE=1
|
PERSISTENCE=1
|
||||||
SKIP_SSL_CERT_DOWNLOAD=1
|
SKIP_SSL_CERT_DOWNLOAD=1
|
||||||
|
|
||||||
# tor
|
# tor proxy
|
||||||
TOR_PROXY=http://127.0.0.1:7050/
|
TOR_PROXY=http://tor:7050/
|
||||||
|
grpc_proxy=http://tor:7050/
|
||||||
|
|
||||||
# lnbits
|
# lnbits
|
||||||
LNBITS_WEB_PORT=5001
|
LNBITS_WEB_PORT=5001
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import { cachedFetcher } from '@/lib/fetch'
|
import { cachedFetcher } from '@/lib/fetch'
|
||||||
import { toPositiveNumber } from '@/lib/validate'
|
import { toPositiveNumber } from '@/lib/validate'
|
||||||
import { authenticatedLndGrpc, getIdentity, getHeight, getWalletInfo, getNode } from 'ln-service'
|
import { authenticatedLndGrpc } from '@/lib/lnd'
|
||||||
|
import { getIdentity, getHeight, getWalletInfo, getNode } from 'ln-service'
|
||||||
|
|
||||||
const lnd = global.lnd || authenticatedLndGrpc({
|
const lnd = global.lnd || authenticatedLndGrpc({
|
||||||
cert: process.env.LND_CERT,
|
cert: process.env.LND_CERT,
|
||||||
|
|
|
@ -40,6 +40,18 @@ services:
|
||||||
labels:
|
labels:
|
||||||
CONNECT: "localhost:5431"
|
CONNECT: "localhost:5431"
|
||||||
cpu_shares: "${CPU_SHARES_IMPORTANT}"
|
cpu_shares: "${CPU_SHARES_IMPORTANT}"
|
||||||
|
tor:
|
||||||
|
build:
|
||||||
|
context: ./docker/tor
|
||||||
|
container_name: tor
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- tordata:/tordata/
|
||||||
|
cpu_shares: "${CPU_SHARES_LOW}"
|
||||||
|
env_file: *env_file
|
||||||
|
healthcheck:
|
||||||
|
<<: *healthcheck
|
||||||
|
test: ["CMD-SHELL", "bash /tor.sh check"]
|
||||||
app:
|
app:
|
||||||
container_name: app
|
container_name: app
|
||||||
stdin_open: true
|
stdin_open: true
|
||||||
|
@ -359,8 +371,13 @@ services:
|
||||||
healthcheck:
|
healthcheck:
|
||||||
<<: *healthcheck
|
<<: *healthcheck
|
||||||
test: ["CMD-SHELL", "lncli", "getinfo"]
|
test: ["CMD-SHELL", "lncli", "getinfo"]
|
||||||
depends_on: *depends_on_bitcoin
|
depends_on:
|
||||||
|
tor:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: true
|
||||||
|
<<: *depends_on_bitcoin
|
||||||
env_file: *env_file
|
env_file: *env_file
|
||||||
|
entrypoint: /tor-entrypoint
|
||||||
command:
|
command:
|
||||||
- 'lnd'
|
- 'lnd'
|
||||||
- '--noseedbackup'
|
- '--noseedbackup'
|
||||||
|
@ -369,6 +386,7 @@ services:
|
||||||
- '--externalip=stacker_lnd'
|
- '--externalip=stacker_lnd'
|
||||||
- '--tlsextradomain=stacker_lnd'
|
- '--tlsextradomain=stacker_lnd'
|
||||||
- '--tlsextradomain=host.docker.internal'
|
- '--tlsextradomain=host.docker.internal'
|
||||||
|
- '--tlsextradomain=$${ONION_DOMAIN}'
|
||||||
- '--listen=0.0.0.0:9735'
|
- '--listen=0.0.0.0:9735'
|
||||||
- '--rpclisten=0.0.0.0:10009'
|
- '--rpclisten=0.0.0.0:10009'
|
||||||
- '--rpcmiddleware.enable'
|
- '--rpcmiddleware.enable'
|
||||||
|
@ -394,6 +412,7 @@ services:
|
||||||
- "${STACKER_LND_GRPC_PORT}:10009"
|
- "${STACKER_LND_GRPC_PORT}:10009"
|
||||||
volumes:
|
volumes:
|
||||||
- stacker_lnd:/home/lnd/.lnd
|
- stacker_lnd:/home/lnd/.lnd
|
||||||
|
- tordata:/home/lnd/.tor
|
||||||
labels:
|
labels:
|
||||||
ofelia.enabled: "true"
|
ofelia.enabled: "true"
|
||||||
ofelia.job-exec.stacker_lnd_channel_cron.schedule: "@every 1m"
|
ofelia.job-exec.stacker_lnd_channel_cron.schedule: "@every 1m"
|
||||||
|
@ -452,7 +471,11 @@ services:
|
||||||
healthcheck:
|
healthcheck:
|
||||||
<<: *healthcheck
|
<<: *healthcheck
|
||||||
test: ["CMD-SHELL", "su clightning -c 'lightning-cli --network=regtest getinfo'"]
|
test: ["CMD-SHELL", "su clightning -c 'lightning-cli --network=regtest getinfo'"]
|
||||||
depends_on: *depends_on_bitcoin
|
depends_on:
|
||||||
|
tor:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: true
|
||||||
|
<<: *depends_on_bitcoin
|
||||||
env_file: *env_file
|
env_file: *env_file
|
||||||
command:
|
command:
|
||||||
- 'lightningd'
|
- 'lightningd'
|
||||||
|
@ -471,6 +494,7 @@ services:
|
||||||
- "${STACKER_CLN_REST_PORT}:3010"
|
- "${STACKER_CLN_REST_PORT}:3010"
|
||||||
volumes:
|
volumes:
|
||||||
- stacker_cln:/home/clightning/.lightning
|
- stacker_cln:/home/clightning/.lightning
|
||||||
|
- tordata:/home/clightning/.tor
|
||||||
labels:
|
labels:
|
||||||
ofelia.enabled: "true"
|
ofelia.enabled: "true"
|
||||||
ofelia.job-exec.stacker_cln_channel_cron.schedule: "@every 1m"
|
ofelia.job-exec.stacker_cln_channel_cron.schedule: "@every 1m"
|
||||||
|
@ -528,8 +552,8 @@ services:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
restart: true
|
restart: true
|
||||||
volumes:
|
volumes:
|
||||||
- ./docker/lnd/stacker:/app/.lnd
|
|
||||||
- nwc_send:/app
|
- nwc_send:/app
|
||||||
|
- stacker_lnd:/app/.lnd
|
||||||
environment:
|
environment:
|
||||||
- RUST_LOG=info
|
- RUST_LOG=info
|
||||||
entrypoint:
|
entrypoint:
|
||||||
|
@ -537,7 +561,7 @@ services:
|
||||||
- '--relay'
|
- '--relay'
|
||||||
- 'wss://relay.primal.net'
|
- 'wss://relay.primal.net'
|
||||||
- '--macaroon-file'
|
- '--macaroon-file'
|
||||||
- '/app/.lnd/regtest/admin.macaroon'
|
- '/app/.lnd/data/chain/bitcoin/regtest/admin.macaroon'
|
||||||
- '--cert-file'
|
- '--cert-file'
|
||||||
- '/app/.lnd/tls.cert'
|
- '/app/.lnd/tls.cert'
|
||||||
- '--lnd-host'
|
- '--lnd-host'
|
||||||
|
@ -562,8 +586,8 @@ services:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
restart: true
|
restart: true
|
||||||
volumes:
|
volumes:
|
||||||
- ./docker/lnd/stacker:/app/.lnd
|
|
||||||
- nwc_recv:/app
|
- nwc_recv:/app
|
||||||
|
- stacker_lnd:/app/.lnd
|
||||||
environment:
|
environment:
|
||||||
- RUST_LOG=info
|
- RUST_LOG=info
|
||||||
entrypoint:
|
entrypoint:
|
||||||
|
@ -571,7 +595,7 @@ services:
|
||||||
- '--relay'
|
- '--relay'
|
||||||
- 'wss://relay.primal.net'
|
- 'wss://relay.primal.net'
|
||||||
- '--invoice-macaroon-file'
|
- '--invoice-macaroon-file'
|
||||||
- '/app/.lnd/regtest/invoice.macaroon'
|
- '/app/.lnd/data/chain/bitcoin/regtest/invoice.macaroon'
|
||||||
- '--cert-file'
|
- '--cert-file'
|
||||||
- '/app/.lnd/tls.cert'
|
- '/app/.lnd/tls.cert'
|
||||||
- '--lnd-host'
|
- '--lnd-host'
|
||||||
|
@ -595,16 +619,22 @@ services:
|
||||||
ports:
|
ports:
|
||||||
- "${LNBITS_WEB_PORT}:5000"
|
- "${LNBITS_WEB_PORT}:5000"
|
||||||
depends_on:
|
depends_on:
|
||||||
- stacker_lnd
|
tor:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: true
|
||||||
|
stacker_lnd:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: true
|
||||||
environment:
|
environment:
|
||||||
- LNBITS_ADMIN_UI=true
|
- LNBITS_ADMIN_UI=true
|
||||||
- LNBITS_BACKEND_WALLET_CLASS=LndWallet
|
- LNBITS_BACKEND_WALLET_CLASS=LndWallet
|
||||||
- LND_GRPC_ENDPOINT=stacker_lnd
|
- LND_GRPC_ENDPOINT=stacker_lnd
|
||||||
- LND_GRPC_PORT=10009
|
- LND_GRPC_PORT=10009
|
||||||
- LND_GRPC_CERT=/app/.lnd/tls.cert
|
- LND_GRPC_CERT=/app/.lnd/tls.cert
|
||||||
- LND_GRPC_MACAROON=/app/.lnd/regtest/admin.macaroon
|
- LND_GRPC_MACAROON=/app/.lnd/data/chain/bitcoin/regtest/admin.macaroon
|
||||||
volumes:
|
volumes:
|
||||||
- ./docker/lnd/stacker:/app/.lnd
|
- stacker_lnd:/app/.lnd
|
||||||
|
- tordata:/app/.tor
|
||||||
labels:
|
labels:
|
||||||
CONNECT: "localhost:${LNBITS_WEB_PORT}"
|
CONNECT: "localhost:${LNBITS_WEB_PORT}"
|
||||||
cpu_shares: "${CPU_SHARES_LOW}"
|
cpu_shares: "${CPU_SHARES_LOW}"
|
||||||
|
@ -618,3 +648,4 @@ volumes:
|
||||||
s3:
|
s3:
|
||||||
nwc_send:
|
nwc_send:
|
||||||
nwc_recv:
|
nwc_recv:
|
||||||
|
tordata:
|
||||||
|
|
Binary file not shown.
|
@ -9,4 +9,7 @@ RUN apt-get update -y \
|
||||||
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
COPY ["./$LN_NODE_FOR/regtest/*", "/home/lnd/.lnd/data/chain/bitcoin/regtest/"]
|
COPY ["./$LN_NODE_FOR/regtest/*", "/home/lnd/.lnd/data/chain/bitcoin/regtest/"]
|
||||||
COPY ["./$LN_NODE_FOR/tls.*", "/home/lnd/.lnd/"]
|
COPY ["./$LN_NODE_FOR/tls.*", "/home/lnd/.lnd/"]
|
||||||
|
|
||||||
|
ADD tor-entrypoint.sh /tor-entrypoint
|
||||||
|
RUN chmod +x /tor-entrypoint
|
|
@ -1,15 +0,0 @@
|
||||||
-----BEGIN CERTIFICATE-----
|
|
||||||
MIICRzCCAe2gAwIBAgIQc06vWIBuP9uKeQNHKbFllDAKBggqhkjOPQQDAjA4MR8w
|
|
||||||
HQYDVQQKExZsbmQgYXV0b2dlbmVyYXRlZCBjZXJ0MRUwEwYDVQQDEww4Y2M4NDFk
|
|
||||||
MjY2MzgwHhcNMjQwMzA3MTcwMjE5WhcNMjUwNTAyMTcwMjE5WjA4MR8wHQYDVQQK
|
|
||||||
ExZsbmQgYXV0b2dlbmVyYXRlZCBjZXJ0MRUwEwYDVQQDEww4Y2M4NDFkMjY2Mzgw
|
|
||||||
WTATBgcqhkjOPQIBBggqhkjOPQMBBwNCAAQT/nwvMHaVCfdVaeIgv8MKS+SHAS9c
|
|
||||||
Elif7Xqa7qsVvPiW7Vnh4MDVEBlM5rg0nkaH6V17sCC3rse/OqPLfVY1o4HYMIHV
|
|
||||||
MA4GA1UdDwEB/wQEAwICpDATBgNVHSUEDDAKBggrBgEFBQcDATAPBgNVHRMBAf8E
|
|
||||||
BTADAQH/MB0GA1UdDgQWBBQmamVn/KcRqHoNR9dk9C1g2M+jSTB+BgNVHREEdzB1
|
|
||||||
ggw4Y2M4NDFkMjY2MziCCWxvY2FsaG9zdIILc3RhY2tlcl9sbmSCFGhvc3QuZG9j
|
|
||||||
a2VyLmludGVybmFsggR1bml4ggp1bml4cGFja2V0ggdidWZjb25uhwR/AAABhxAA
|
|
||||||
AAAAAAAAAAAAAAAAAAABhwSsGwAGMAoGCCqGSM49BAMCA0gAMEUCIFD273WBcMKz
|
|
||||||
UPoOL8bwq15JXtrSGePKpAeN1TblY4Q5AiEAvKtuk+ssx9WQFZBEiWxCSjW5geKk
|
|
||||||
6HB7TdxsU+ZbfLg=
|
|
||||||
-----END CERTIFICATE-----
|
|
|
@ -1,5 +0,0 @@
|
||||||
-----BEGIN EC PRIVATE KEY-----
|
|
||||||
MHcCAQEEIOxH9uY8mpnlo/X5gRAAVOzOuEPIAOuHHlezkba3vIuHoAoGCCqGSM49
|
|
||||||
AwEHoUQDQgAEE/58LzB2lQn3VWniIL/DCkvkhwEvXBJYn+16mu6rFbz4lu1Z4eDA
|
|
||||||
1RAZTOa4NJ5Gh+lde7Agt67Hvzqjy31WNQ==
|
|
||||||
-----END EC PRIVATE KEY-----
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
ONION_DOMAIN=""
|
||||||
|
|
||||||
|
if [ -f /home/lnd/.tor/hidden_service/hostname ]; then
|
||||||
|
ONION_DOMAIN=$(cat /home/lnd/.tor/hidden_service/hostname)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# expand the cmd arguments
|
||||||
|
args=$(echo "$@" | sed -e "s/\${ONION_DOMAIN}/$ONION_DOMAIN/g")
|
||||||
|
|
||||||
|
# Execute the original entry point script with the modified command line``
|
||||||
|
/entrypoint.sh $args
|
|
@ -0,0 +1,15 @@
|
||||||
|
FROM debian:bookworm
|
||||||
|
|
||||||
|
RUN apt-get update -y \
|
||||||
|
&& apt-get install -y tor bash openssl netcat-traditional \
|
||||||
|
&& apt-get clean \
|
||||||
|
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
ADD torrc /etc/tor/torrc.template
|
||||||
|
ADD tor.sh /tor.sh
|
||||||
|
ADD services.conf /services.conf
|
||||||
|
RUN mkdir -p /tordata && groupadd -g 1000 tor && useradd -u 1000 -g 1000 -m tor && chown -R tor:tor /tordata
|
||||||
|
EXPOSE 9050 9051 7050
|
||||||
|
VOLUME "/tordata"
|
||||||
|
USER tor
|
||||||
|
ENTRYPOINT [ "bash", "/tor.sh" ]
|
|
@ -0,0 +1,3 @@
|
||||||
|
HiddenServicePort 10009 stacker_lnd:10009
|
||||||
|
HiddenServicePort 3010 stacker_cln:3010
|
||||||
|
HiddenServicePort 5000 lnbits:5000
|
|
@ -0,0 +1,68 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
function initialize {
|
||||||
|
####################### generate and save control password ########################
|
||||||
|
cp -f /etc/tor/torrc.template /tordata/torrc
|
||||||
|
TOR_PASSWORD=""
|
||||||
|
if [ -f /tordata/.env.torpass ]; then source /tordata/.env.torpass; fi
|
||||||
|
|
||||||
|
if [ -z "$torPassword" ]; then
|
||||||
|
TOR_PASSWORD=$(openssl rand -hex 32)
|
||||||
|
echo "TOR_PASSWORD=$TOR_PASSWORD" > /tordata/.env.torpass
|
||||||
|
fi
|
||||||
|
|
||||||
|
TOR_PASSWORD_HASH=$(tor --hash-password "$TOR_PASSWORD" 2>/dev/null | tail -n 1)
|
||||||
|
echo "Replacing %HashedControlPassword% with $TOR_PASSWORD_HASH"
|
||||||
|
sed -i "s|%HashedControlPassword%|$TOR_PASSWORD_HASH|g" /tordata/torrc
|
||||||
|
##################################################################################
|
||||||
|
}
|
||||||
|
|
||||||
|
function mergeServices {
|
||||||
|
cat /services.conf >> /tordata/torrc
|
||||||
|
}
|
||||||
|
|
||||||
|
# There is a circular dependency between tor and stacker_lnd:
|
||||||
|
# <-> tor needs stacker_lnd to be running to resolve the hidden service target
|
||||||
|
# <-> stacker_lnd needs to wait for tor to start and generate the hidden service address
|
||||||
|
# Afaik there isn't an "official" solution for this issue.
|
||||||
|
#
|
||||||
|
# This workaround starts tor the first time without the lnd hidden service
|
||||||
|
# and then re-start tor with the full configuration after the lnd service is ready.
|
||||||
|
|
||||||
|
|
||||||
|
if [ -f /tordata/start.timestamp ];
|
||||||
|
then
|
||||||
|
# Remove leftovers from a previous run
|
||||||
|
rm /tordata/start.timestamp
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = "check" ];
|
||||||
|
then
|
||||||
|
if [ ! -f /tordata/start.timestamp ]; then
|
||||||
|
# if still initializing we just check if the hidden service was generated and use this as a healthcheck
|
||||||
|
if [ -f /tordata/hidden_service/hostname ]; then exit 0; else exit 1; fi
|
||||||
|
else
|
||||||
|
# run the real healthcheck
|
||||||
|
echo -e 'AUTHENTICATE "'$TOR_PASSWORD'"\nGETINFO status/circuit-established\nQUIT' | nc 127.0.0.1 9051 | grep OK || exit 1
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
# Step 1: we start tor with a fake hidden service that points to port 8080,
|
||||||
|
# just to get it to generate the hidden service data, then we kill it immediately after
|
||||||
|
echo "Initializing..."
|
||||||
|
initialize
|
||||||
|
tor -f /tordata/torrc &
|
||||||
|
pid=$!
|
||||||
|
sleep 60
|
||||||
|
kill $pid
|
||||||
|
|
||||||
|
# debug
|
||||||
|
ls /tordata/hidden_service/
|
||||||
|
|
||||||
|
# Step 2: we merge the service configuration and start tor again
|
||||||
|
echo "Starting tor..."
|
||||||
|
initialize
|
||||||
|
mergeServices
|
||||||
|
date +%s > /tordata/start.timestamp
|
||||||
|
tor -f /tordata/torrc
|
||||||
|
fi
|
|
@ -0,0 +1,260 @@
|
||||||
|
## Configuration file for a typical Tor user
|
||||||
|
## Last updated 28 February 2019 for Tor 0.3.5.1-alpha.
|
||||||
|
## (may or may not work for much older or much newer versions of Tor.)
|
||||||
|
##
|
||||||
|
## Lines that begin with "## " try to explain what's going on. Lines
|
||||||
|
## that begin with just "#" are disabled commands: you can enable them
|
||||||
|
## by removing the "#" symbol.
|
||||||
|
##
|
||||||
|
## See 'man tor', or https://www.torproject.org/docs/tor-manual.html,
|
||||||
|
## for more options you can use in this file.
|
||||||
|
##
|
||||||
|
## Tor will look for this file in various places based on your platform:
|
||||||
|
## https://support.torproject.org/tbb/tbb-editing-torrc/
|
||||||
|
|
||||||
|
## Tor opens a SOCKS proxy on port 9050 by default -- even if you don't
|
||||||
|
## configure one below. Set "SOCKSPort 0" if you plan to run Tor only
|
||||||
|
## as a relay, and not make any local application connections yourself.
|
||||||
|
SOCKSPort 0.0.0.0:9050 # Default: Bind to localhost:9050 for local connections.
|
||||||
|
#SOCKSPort 192.168.0.1:9100 # Bind to this address:port too.
|
||||||
|
HTTPTunnelPort 0.0.0.0:7050
|
||||||
|
## Entry policies to allow/deny SOCKS requests based on IP address.
|
||||||
|
## First entry that matches wins. If no SOCKSPolicy is set, we accept
|
||||||
|
## all (and only) requests that reach a SOCKSPort. Untrusted users who
|
||||||
|
## can access your SOCKSPort may be able to learn about the connections
|
||||||
|
## you make.
|
||||||
|
#SOCKSPolicy accept 192.168.0.0/16
|
||||||
|
#SOCKSPolicy accept6 FC00::/7
|
||||||
|
SOCKSPolicy accept *
|
||||||
|
|
||||||
|
## Logs go to stdout at level "notice" unless redirected by something
|
||||||
|
## else, like one of the below lines. You can have as many Log lines as
|
||||||
|
## you want.
|
||||||
|
##
|
||||||
|
## We advise using "notice" in most cases, since anything more verbose
|
||||||
|
## may provide sensitive information to an attacker who obtains the logs.
|
||||||
|
##
|
||||||
|
## Send all messages of level 'notice' or higher to @LOCALSTATEDIR@/log/tor/notices.log
|
||||||
|
#Log notice file @LOCALSTATEDIR@/log/tor/notices.log
|
||||||
|
## Send every possible message to @LOCALSTATEDIR@/log/tor/debug.log
|
||||||
|
#Log debug file @LOCALSTATEDIR@/log/tor/debug.log
|
||||||
|
## Use the system log instead of Tor's logfiles
|
||||||
|
Log notice stdout
|
||||||
|
## To send all messages to stderr:
|
||||||
|
#Log debug stderr
|
||||||
|
|
||||||
|
## Uncomment this to start the process in the background... or use
|
||||||
|
## --runasdaemon 1 on the command line. This is ignored on Windows;
|
||||||
|
## see the FAQ entry if you want Tor to run as an NT service.
|
||||||
|
#RunAsDaemon 1
|
||||||
|
|
||||||
|
## The directory for keeping all the keys/etc. By default, we store
|
||||||
|
## things in $HOME/.tor on Unix, and in Application Data\tor on Windows.
|
||||||
|
#DataDirectory @LOCALSTATEDIR@/lib/tor
|
||||||
|
|
||||||
|
## The port on which Tor will listen for local connections from Tor
|
||||||
|
## controller applications, as documented in control-spec.txt.
|
||||||
|
ControlPort 127.0.0.1:9051
|
||||||
|
## If you enable the controlport, be sure to enable one of these
|
||||||
|
## authentication methods, to prevent attackers from accessing it.
|
||||||
|
HashedControlPassword %HashedControlPassword%
|
||||||
|
#CookieAuthentication 1
|
||||||
|
|
||||||
|
############### This section is just for location-hidden services ###
|
||||||
|
|
||||||
|
## Once you have configured a hidden service, you can look at the
|
||||||
|
## contents of the file ".../hidden_service/hostname" for the address
|
||||||
|
## to tell people.
|
||||||
|
##
|
||||||
|
## HiddenServicePort x y:z says to redirect requests on port x to the
|
||||||
|
## address y:z.
|
||||||
|
|
||||||
|
#HiddenServiceDir @LOCALSTATEDIR@/lib/tor/hidden_service/
|
||||||
|
#HiddenServicePort 80 127.0.0.1:80
|
||||||
|
|
||||||
|
HiddenServiceDir /tordata/hidden_service/
|
||||||
|
# Fake service just to initialize the hidden service directory
|
||||||
|
HiddenServicePort 8080 127.0.0.1:8080
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
################ This section is just for relays #####################
|
||||||
|
#
|
||||||
|
## See https://community.torproject.org/relay for details.
|
||||||
|
|
||||||
|
## Required: what port to advertise for incoming Tor connections.
|
||||||
|
#ORPort 9001
|
||||||
|
## If you want to listen on a port other than the one advertised in
|
||||||
|
## ORPort (e.g. to advertise 443 but bind to 9090), you can do it as
|
||||||
|
## follows. You'll need to do ipchains or other port forwarding
|
||||||
|
## yourself to make this work.
|
||||||
|
#ORPort 443 NoListen
|
||||||
|
#ORPort 127.0.0.1:9090 NoAdvertise
|
||||||
|
## If you want to listen on IPv6 your numeric address must be explicitly
|
||||||
|
## between square brackets as follows. You must also listen on IPv4.
|
||||||
|
#ORPort [2001:DB8::1]:9050
|
||||||
|
|
||||||
|
## The IP address or full DNS name for incoming connections to your
|
||||||
|
## relay. Leave commented out and Tor will guess.
|
||||||
|
#Address noname.example.com
|
||||||
|
|
||||||
|
## If you have multiple network interfaces, you can specify one for
|
||||||
|
## outgoing traffic to use.
|
||||||
|
## OutboundBindAddressExit will be used for all exit traffic, while
|
||||||
|
## OutboundBindAddressOR will be used for all OR and Dir connections
|
||||||
|
## (DNS connections ignore OutboundBindAddress).
|
||||||
|
## If you do not wish to differentiate, use OutboundBindAddress to
|
||||||
|
## specify the same address for both in a single line.
|
||||||
|
#OutboundBindAddressExit 10.0.0.4
|
||||||
|
#OutboundBindAddressOR 10.0.0.5
|
||||||
|
|
||||||
|
## A handle for your relay, so people don't have to refer to it by key.
|
||||||
|
## Nicknames must be between 1 and 19 characters inclusive, and must
|
||||||
|
## contain only the characters [a-zA-Z0-9].
|
||||||
|
## If not set, "Unnamed" will be used.
|
||||||
|
#Nickname ididnteditheconfig
|
||||||
|
|
||||||
|
## Define these to limit how much relayed traffic you will allow. Your
|
||||||
|
## own traffic is still unthrottled. Note that RelayBandwidthRate must
|
||||||
|
## be at least 75 kilobytes per second.
|
||||||
|
## Note that units for these config options are bytes (per second), not
|
||||||
|
## bits (per second), and that prefixes are binary prefixes, i.e. 2^10,
|
||||||
|
## 2^20, etc.
|
||||||
|
#RelayBandwidthRate 100 KBytes # Throttle traffic to 100KB/s (800Kbps)
|
||||||
|
#RelayBandwidthBurst 200 KBytes # But allow bursts up to 200KB (1600Kb)
|
||||||
|
|
||||||
|
## Use these to restrict the maximum traffic per day, week, or month.
|
||||||
|
## Note that this threshold applies separately to sent and received bytes,
|
||||||
|
## not to their sum: setting "40 GB" may allow up to 80 GB total before
|
||||||
|
## hibernating.
|
||||||
|
##
|
||||||
|
## Set a maximum of 40 gigabytes each way per period.
|
||||||
|
#AccountingMax 40 GBytes
|
||||||
|
## Each period starts daily at midnight (AccountingMax is per day)
|
||||||
|
#AccountingStart day 00:00
|
||||||
|
## Each period starts on the 3rd of the month at 15:00 (AccountingMax
|
||||||
|
## is per month)
|
||||||
|
#AccountingStart month 3 15:00
|
||||||
|
|
||||||
|
## Administrative contact information for this relay or bridge. This line
|
||||||
|
## can be used to contact you if your relay or bridge is misconfigured or
|
||||||
|
## something else goes wrong. Note that we archive and publish all
|
||||||
|
## descriptors containing these lines and that Google indexes them, so
|
||||||
|
## spammers might also collect them. You may want to obscure the fact that
|
||||||
|
## it's an email address and/or generate a new address for this purpose.
|
||||||
|
##
|
||||||
|
## If you are running multiple relays, you MUST set this option.
|
||||||
|
##
|
||||||
|
#ContactInfo Random Person <nobody AT example dot com>
|
||||||
|
## You might also include your PGP or GPG fingerprint if you have one:
|
||||||
|
#ContactInfo 0xFFFFFFFF Random Person <nobody AT example dot com>
|
||||||
|
|
||||||
|
## Uncomment this to mirror directory information for others. Please do
|
||||||
|
## if you have enough bandwidth.
|
||||||
|
#DirPort 9030 # what port to advertise for directory connections
|
||||||
|
## If you want to listen on a port other than the one advertised in
|
||||||
|
## DirPort (e.g. to advertise 80 but bind to 9091), you can do it as
|
||||||
|
## follows. below too. You'll need to do ipchains or other port
|
||||||
|
## forwarding yourself to make this work.
|
||||||
|
#DirPort 80 NoListen
|
||||||
|
#DirPort 127.0.0.1:9091 NoAdvertise
|
||||||
|
## Uncomment to return an arbitrary blob of html on your DirPort. Now you
|
||||||
|
## can explain what Tor is if anybody wonders why your IP address is
|
||||||
|
## contacting them. See contrib/tor-exit-notice.html in Tor's source
|
||||||
|
## distribution for a sample.
|
||||||
|
#DirPortFrontPage @CONFDIR@/tor-exit-notice.html
|
||||||
|
|
||||||
|
## Uncomment this if you run more than one Tor relay, and add the identity
|
||||||
|
## key fingerprint of each Tor relay you control, even if they're on
|
||||||
|
## different networks. You declare it here so Tor clients can avoid
|
||||||
|
## using more than one of your relays in a single circuit. See
|
||||||
|
## https://support.torproject.org/relay-operators/multiple-relays/
|
||||||
|
## However, you should never include a bridge's fingerprint here, as it would
|
||||||
|
## break its concealability and potentially reveal its IP/TCP address.
|
||||||
|
##
|
||||||
|
## If you are running multiple relays, you MUST set this option.
|
||||||
|
##
|
||||||
|
## Note: do not use MyFamily on bridge relays.
|
||||||
|
#MyFamily $keyid,$keyid,...
|
||||||
|
|
||||||
|
## Uncomment this if you want your relay to be an exit, with the default
|
||||||
|
## exit policy (or whatever exit policy you set below).
|
||||||
|
## (If ReducedExitPolicy, ExitPolicy, or IPv6Exit are set, relays are exits.
|
||||||
|
## If none of these options are set, relays are non-exits.)
|
||||||
|
#ExitRelay 1
|
||||||
|
|
||||||
|
## Uncomment this if you want your relay to allow IPv6 exit traffic.
|
||||||
|
## (Relays do not allow any exit traffic by default.)
|
||||||
|
#IPv6Exit 1
|
||||||
|
|
||||||
|
## Uncomment this if you want your relay to be an exit, with a reduced set
|
||||||
|
## of exit ports.
|
||||||
|
#ReducedExitPolicy 1
|
||||||
|
|
||||||
|
## Uncomment these lines if you want your relay to be an exit, with the
|
||||||
|
## specified set of exit IPs and ports.
|
||||||
|
##
|
||||||
|
## A comma-separated list of exit policies. They're considered first
|
||||||
|
## to last, and the first match wins.
|
||||||
|
##
|
||||||
|
## If you want to allow the same ports on IPv4 and IPv6, write your rules
|
||||||
|
## using accept/reject *. If you want to allow different ports on IPv4 and
|
||||||
|
## IPv6, write your IPv6 rules using accept6/reject6 *6, and your IPv4 rules
|
||||||
|
## using accept/reject *4.
|
||||||
|
##
|
||||||
|
## If you want to _replace_ the default exit policy, end this with either a
|
||||||
|
## reject *:* or an accept *:*. Otherwise, you're _augmenting_ (prepending to)
|
||||||
|
## the default exit policy. Leave commented to just use the default, which is
|
||||||
|
## described in the man page or at
|
||||||
|
## https://support.torproject.org/relay-operators
|
||||||
|
##
|
||||||
|
## Look at https://support.torproject.org/abuse/exit-relay-expectations/
|
||||||
|
## for issues you might encounter if you use the default exit policy.
|
||||||
|
##
|
||||||
|
## If certain IPs and ports are blocked externally, e.g. by your firewall,
|
||||||
|
## you should update your exit policy to reflect this -- otherwise Tor
|
||||||
|
## users will be told that those destinations are down.
|
||||||
|
##
|
||||||
|
## For security, by default Tor rejects connections to private (local)
|
||||||
|
## networks, including to the configured primary public IPv4 and IPv6 addresses,
|
||||||
|
## and any public IPv4 and IPv6 addresses on any interface on the relay.
|
||||||
|
## See the man page entry for ExitPolicyRejectPrivate if you want to allow
|
||||||
|
## "exit enclaving".
|
||||||
|
##
|
||||||
|
#ExitPolicy accept *:6660-6667,reject *:* # allow irc ports on IPv4 and IPv6 but no more
|
||||||
|
#ExitPolicy accept *:119 # accept nntp ports on IPv4 and IPv6 as well as default exit policy
|
||||||
|
#ExitPolicy accept *4:119 # accept nntp ports on IPv4 only as well as default exit policy
|
||||||
|
#ExitPolicy accept6 *6:119 # accept nntp ports on IPv6 only as well as default exit policy
|
||||||
|
#ExitPolicy reject *:* # no exits allowed
|
||||||
|
|
||||||
|
## Uncomment this if you want your exit relay to reevaluate its exit policy on
|
||||||
|
## existing connections when the exit policy is modified.
|
||||||
|
#ReevaluateExitPolicy 1
|
||||||
|
|
||||||
|
## Bridge relays (or "bridges") are Tor relays that aren't listed in the
|
||||||
|
## main directory. Since there is no complete public list of them, even an
|
||||||
|
## ISP that filters connections to all the known Tor relays probably
|
||||||
|
## won't be able to block all the bridges. Also, websites won't treat you
|
||||||
|
## differently because they won't know you're running Tor. If you can
|
||||||
|
## be a real relay, please do; but if not, be a bridge!
|
||||||
|
##
|
||||||
|
## Warning: when running your Tor as a bridge, make sure than MyFamily is
|
||||||
|
## NOT configured.
|
||||||
|
#BridgeRelay 1
|
||||||
|
## By default, Tor will advertise your bridge to users through various
|
||||||
|
## mechanisms like https://bridges.torproject.org/. If you want to run
|
||||||
|
## a private bridge, for example because you'll give out your bridge
|
||||||
|
## address manually to your friends, uncomment this line:
|
||||||
|
#BridgeDistribution none
|
||||||
|
|
||||||
|
## Configuration options can be imported from files or folders using the %include
|
||||||
|
## option with the value being a path. This path can have wildcards. Wildcards are
|
||||||
|
## expanded first, using lexical order. Then, for each matching file or folder, the following
|
||||||
|
## rules are followed: if the path is a file, the options from the file will be parsed as if
|
||||||
|
## they were written where the %include option is. If the path is a folder, all files on that
|
||||||
|
## folder will be parsed following lexical order. Files starting with a dot are ignored. Files
|
||||||
|
## on subfolders are ignored.
|
||||||
|
## The %include option can be used recursively.
|
||||||
|
#%include /etc/torrc.d/*.conf
|
||||||
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
// fork of https://github.com/alexbosworth/lightning/blob/master/lnd_grpc/authenticated_lnd_grpc.js
|
||||||
|
// that allows to enable or disable proxy
|
||||||
|
|
||||||
|
import { join } from 'path'
|
||||||
|
import apiForProto from 'lightning/lnd_grpc/api_for_proto'
|
||||||
|
import { defaultSocket, grpcSslCipherSuites, packageTypes, protoFiles, protosDir, serviceTypes } from 'lightning/grpc/index'
|
||||||
|
import grpcCredentials from 'lightning/lnd_grpc/grpc_credentials'
|
||||||
|
import { createRequire } from 'module'
|
||||||
|
|
||||||
|
const { GRPC_SSL_CIPHER_SUITES } = process.env
|
||||||
|
const { keys } = Object
|
||||||
|
|
||||||
|
export function authenticatedLndGrpc ({ cert, macaroon, path, socket }, withProxy) {
|
||||||
|
const req = createRequire(import.meta.url)
|
||||||
|
|
||||||
|
const lightningModulePath = req.resolve('lightning')
|
||||||
|
const pathForProto = proto => join(lightningModulePath, protosDir, proto)
|
||||||
|
|
||||||
|
const { credentials } = grpcCredentials({ cert, macaroon })
|
||||||
|
const lndSocket = socket || defaultSocket
|
||||||
|
|
||||||
|
if (!!cert && GRPC_SSL_CIPHER_SUITES !== grpcSslCipherSuites) {
|
||||||
|
process.env.GRPC_SSL_CIPHER_SUITES = grpcSslCipherSuites
|
||||||
|
}
|
||||||
|
|
||||||
|
const params = {
|
||||||
|
'grpc.max_receive_message_length': -1,
|
||||||
|
'grpc.max_send_message_length': -1,
|
||||||
|
'grpc.enable_http_proxy': withProxy ? 1 : 0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Assemble different services from their proto files
|
||||||
|
return {
|
||||||
|
lnd: keys(serviceTypes).reduce((services, type) => {
|
||||||
|
const service = serviceTypes[type]
|
||||||
|
|
||||||
|
const file = protoFiles[service]
|
||||||
|
|
||||||
|
services[type] = apiForProto({
|
||||||
|
credentials,
|
||||||
|
params,
|
||||||
|
service,
|
||||||
|
path: path ? join(path, file) : pathForProto(file),
|
||||||
|
socket: lndSocket,
|
||||||
|
type: packageTypes[service]
|
||||||
|
})
|
||||||
|
|
||||||
|
return services
|
||||||
|
},
|
||||||
|
{})
|
||||||
|
}
|
||||||
|
}
|
135
sndev
135
sndev
|
@ -56,12 +56,19 @@ docker__stacker_lnd() {
|
||||||
|
|
||||||
docker__stacker_cln() {
|
docker__stacker_cln() {
|
||||||
t=$1
|
t=$1
|
||||||
|
|
||||||
if [ "$t" = "-t" ]; then
|
if [ "$t" = "-t" ]; then
|
||||||
shift
|
shift
|
||||||
else
|
else
|
||||||
t=""
|
t=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = "get_onion" ]; then
|
||||||
|
onion="$(docker__exec $t stacker_cln cat /home/clightning/.tor/hidden_service/hostname | tr -d '[:space:]')"
|
||||||
|
echo "$onion:3010"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
docker__exec $t -u clightning stacker_cln lightning-cli --regtest "$@"
|
docker__exec $t -u clightning stacker_cln lightning-cli --regtest "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -414,6 +421,9 @@ sndev__stacker_clncli() {
|
||||||
|
|
||||||
sndev__help_stacker_clncli() {
|
sndev__help_stacker_clncli() {
|
||||||
docker__stacker_cln help
|
docker__stacker_cln help
|
||||||
|
echo
|
||||||
|
echo "EXTRA:"
|
||||||
|
echo " get_onion get the onion address"
|
||||||
}
|
}
|
||||||
|
|
||||||
sndev__stacker_litcli() {
|
sndev__stacker_litcli() {
|
||||||
|
@ -524,6 +534,80 @@ USAGE
|
||||||
echo "$help"
|
echo "$help"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sndev__help_stacker_lnd() {
|
||||||
|
help="
|
||||||
|
|
||||||
|
USAGE
|
||||||
|
$ sndev stacker_lnd get_cert get the tls cert
|
||||||
|
$ sndev stacker_lnd get_onion get the onion address
|
||||||
|
"
|
||||||
|
|
||||||
|
echo "$help"
|
||||||
|
}
|
||||||
|
|
||||||
|
sndev__stacker_lnd() {
|
||||||
|
shift
|
||||||
|
if [ -z "$1" ]; then
|
||||||
|
echo "no command provided"
|
||||||
|
sndev__help_stacker_lnd
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "$1" = "get_cert" ]; then
|
||||||
|
echo $(docker__exec -t stacker_lnd openssl base64 -A -in /home/lnd/.lnd/tls.cert)
|
||||||
|
elif [ "$1" = "get_onion" ];
|
||||||
|
then
|
||||||
|
onion="$(docker__exec -t stacker_lnd cat /home/lnd/.tor/hidden_service/hostname | tr -d '[:space:]')"
|
||||||
|
echo "$onion:10009"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
sndev__help_lnbits() {
|
||||||
|
help="
|
||||||
|
|
||||||
|
USAGE
|
||||||
|
$ sndev stacker_lnbits get_onion get the onion address
|
||||||
|
"
|
||||||
|
}
|
||||||
|
|
||||||
|
sndev__lnbits() {
|
||||||
|
shift
|
||||||
|
if [ -z "$1" ]; then
|
||||||
|
echo "no command provided"
|
||||||
|
sndev__help_lnbits
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "$1" = "get_onion" ];
|
||||||
|
then
|
||||||
|
onion="$(docker__exec -t lnbits cat /app/.tor/hidden_service/hostname | tr -d '[:space:]')"
|
||||||
|
echo "$onion:5000"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sndev__help_tor() {
|
||||||
|
help="
|
||||||
|
|
||||||
|
USAGE
|
||||||
|
$ sndev tor get_onion get the onion address
|
||||||
|
"
|
||||||
|
|
||||||
|
echo "$help"
|
||||||
|
}
|
||||||
|
|
||||||
|
sndev__tor() {
|
||||||
|
shift
|
||||||
|
if [ -z "$1" ]; then
|
||||||
|
echo "no command provided"
|
||||||
|
sndev__help_tor
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "$1" = "get_onion" ];
|
||||||
|
then
|
||||||
|
onion="$(docker__exec -t stacker_lnd cat /home/lnd/.tor/hidden_service/hostname | tr -d '[:space:]')"
|
||||||
|
echo "$onion"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
sndev__help() {
|
sndev__help() {
|
||||||
if [ $# -eq 2 ]; then
|
if [ $# -eq 2 ]; then
|
||||||
call "sndev__$1_$2" "$@"
|
call "sndev__$1_$2" "$@"
|
||||||
|
@ -547,43 +631,48 @@ USAGE
|
||||||
$ sndev help [COMMAND]
|
$ sndev help [COMMAND]
|
||||||
|
|
||||||
COMMANDS
|
COMMANDS
|
||||||
help show help
|
help show help
|
||||||
|
|
||||||
env:
|
env:
|
||||||
start start env
|
start start env
|
||||||
stop stop env
|
stop stop env
|
||||||
restart restart env
|
restart restart env
|
||||||
status status of env
|
status status of env
|
||||||
logs logs from env
|
logs logs from env
|
||||||
delete delete env
|
delete delete env
|
||||||
|
|
||||||
sn:
|
sn:
|
||||||
login login as a nym
|
login login as a nym
|
||||||
fund_user fund a nym without using an LN invoice
|
fund_user fund a nym without using an LN invoice
|
||||||
|
|
||||||
lnd:
|
lnd:
|
||||||
fund pay a bolt11 for funding
|
fund pay a bolt11 for funding
|
||||||
withdraw create a bolt11 for withdrawal
|
withdraw create a bolt11 for withdrawal
|
||||||
|
|
||||||
cln:
|
cln:
|
||||||
cln_fund pay a bolt11 for funding with CLN
|
cln_fund pay a bolt11 for funding with CLN
|
||||||
cln_withdraw create a bolt11 for withdrawal with CLN
|
cln_withdraw create a bolt11 for withdrawal with CLN
|
||||||
|
|
||||||
db:
|
db:
|
||||||
psql open psql on db
|
psql open psql on db
|
||||||
prisma run prisma commands
|
prisma run prisma commands
|
||||||
|
|
||||||
dev:
|
dev:
|
||||||
pr fetch and checkout a pr
|
pr fetch and checkout a pr
|
||||||
lint run linters
|
lint run linters
|
||||||
open open container url in browser
|
open open container url in browser
|
||||||
|
|
||||||
other:
|
other:
|
||||||
compose docker compose passthrough
|
compose docker compose passthrough
|
||||||
sn_lndcli lncli passthrough on sn_lnd
|
sn_lndcli lncli passthrough on sn_lnd
|
||||||
stacker_lndcli lncli passthrough on stacker_lnd
|
stacker_lndcli lncli passthrough on stacker_lnd
|
||||||
stacker_clncli lightning-cli passthrough on stacker_cln
|
stacker_clncli lightning-cli passthrough on stacker_cln
|
||||||
stacker_litcli litcli passthrough on litd
|
stacker_litcli litcli passthrough on litd
|
||||||
|
tor get_onion get the onion address
|
||||||
|
stacker_lnd get_cert get the tls cert
|
||||||
|
stacker_lnd get_onion get the onion address
|
||||||
|
stacker_clncli get_onion get the onion address
|
||||||
|
lndbits get_onion get the onion address
|
||||||
"
|
"
|
||||||
echo "$help"
|
echo "$help"
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,14 @@ For testing cln as an attached receiving wallet, you'll need a rune and the cert
|
||||||
|
|
||||||
`stacker_cln:3010`
|
`stacker_cln:3010`
|
||||||
|
|
||||||
|
# host and port (onion)
|
||||||
|
|
||||||
|
Run:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sndev stacker_clncli get_onion
|
||||||
|
```
|
||||||
|
|
||||||
# create rune
|
# create rune
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
|
|
|
@ -22,3 +22,12 @@ Or simply copy the keys from here:
|
||||||
( These keys can be found under `Node URL, API keys and API docs`. )
|
( These keys can be found under `Node URL, API keys and API docs`. )
|
||||||
|
|
||||||
To use the same URL to connect to LNbits in the browser and server during local development, `localhost:<port>` is mapped to `lnbits:5000` on the server.
|
To use the same URL to connect to LNbits in the browser and server during local development, `localhost:<port>` is mapped to `lnbits:5000` on the server.
|
||||||
|
|
||||||
|
|
||||||
|
# tor onion url
|
||||||
|
|
||||||
|
Run the following command to get the onion url:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sndev lnbits get_onion
|
||||||
|
```
|
|
@ -1,5 +1,6 @@
|
||||||
import { msatsToSats } from '@/lib/format'
|
import { msatsToSats } from '@/lib/format'
|
||||||
import { getAgent } from '@/lib/proxy'
|
import { getAgent } from '@/lib/proxy'
|
||||||
|
import fetch from 'cross-fetch'
|
||||||
|
|
||||||
export * from 'wallets/lnbits'
|
export * from 'wallets/lnbits'
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,14 @@ For testing lnd as an attached receiving wallet, you'll need a macaroon and the
|
||||||
|
|
||||||
`stacker_lnd:10009`
|
`stacker_lnd:10009`
|
||||||
|
|
||||||
|
## host and port (onion)
|
||||||
|
|
||||||
|
To get the onion address run this command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sndev stacker_lnd get_onion
|
||||||
|
```
|
||||||
|
|
||||||
# generate macaroon
|
# generate macaroon
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
|
@ -12,14 +20,8 @@ sndev stacker_lndcli -n regtest bakemacaroon invoices:write invoices:read
|
||||||
|
|
||||||
# get cert
|
# get cert
|
||||||
|
|
||||||
This is static in dev env so you can use this one:
|
To get the cert run this command:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUNSekNDQWUyZ0F3SUJBZ0lRYzA2dldJQnVQOXVLZVFOSEtiRmxsREFLQmdncWhrak9QUVFEQWpBNE1SOHcKSFFZRFZRUUtFeFpzYm1RZ1lYVjBiMmRsYm1WeVlYUmxaQ0JqWlhKME1SVXdFd1lEVlFRREV3dzRZMk00TkRGawpNalkyTXpnd0hoY05NalF3TXpBM01UY3dNakU1V2hjTk1qVXdOVEF5TVRjd01qRTVXakE0TVI4d0hRWURWUVFLCkV4WnNibVFnWVhWMGIyZGxibVZ5WVhSbFpDQmpaWEowTVJVd0V3WURWUVFERXd3NFkyTTROREZrTWpZMk16Z3cKV1RBVEJnY3Foa2pPUFFJQkJnZ3Foa2pPUFFNQkJ3TkNBQVFUL253dk1IYVZDZmRWYWVJZ3Y4TUtTK1NIQVM5YwpFbGlmN1hxYTdxc1Z2UGlXN1ZuaDRNRFZFQmxNNXJnMG5rYUg2VjE3c0NDM3JzZS9PcVBMZlZZMW80SFlNSUhWCk1BNEdBMVVkRHdFQi93UUVBd0lDcERBVEJnTlZIU1VFRERBS0JnZ3JCZ0VGQlFjREFUQVBCZ05WSFJNQkFmOEUKQlRBREFRSC9NQjBHQTFVZERnUVdCQlFtYW1Wbi9LY1JxSG9OUjlkazlDMWcyTStqU1RCK0JnTlZIUkVFZHpCMQpnZ3c0WTJNNE5ERmtNalkyTXppQ0NXeHZZMkZzYUc5emRJSUxjM1JoWTJ0bGNsOXNibVNDRkdodmMzUXVaRzlqCmEyVnlMbWx1ZEdWeWJtRnNnZ1IxYm1sNGdncDFibWw0Y0dGamEyVjBnZ2RpZFdaamIyNXVod1IvQUFBQmh4QUEKQUFBQUFBQUFBQUFBQUFBQUFBQUJod1NzR3dBR01Bb0dDQ3FHU000OUJBTUNBMGdBTUVVQ0lGRDI3M1dCY01LegpVUG9PTDhid3ExNUpYdHJTR2VQS3BBZU4xVGJsWTRRNUFpRUF2S3R1aytzc3g5V1FGWkJFaVd4Q1NqVzVnZUtrCjZIQjdUZHhzVStaYmZMZz0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
|
sndev stacker_lnd get_cert
|
||||||
```
|
|
||||||
|
|
||||||
Which is generated with the following command
|
|
||||||
|
|
||||||
```bash
|
|
||||||
openssl base64 -A -in docker/lnd/stacker/tls.cert
|
|
||||||
```
|
```
|
|
@ -1,5 +1,7 @@
|
||||||
import { datePivot } from '@/lib/time'
|
import { datePivot } from '@/lib/time'
|
||||||
import { authenticatedLndGrpc, createInvoice as lndCreateInvoice } from 'ln-service'
|
import { authenticatedLndGrpc } from '@/lib/lnd'
|
||||||
|
import { createInvoice as lndCreateInvoice } from 'ln-service'
|
||||||
|
import { TOR_REGEXP } from '@/lib/url'
|
||||||
|
|
||||||
export * from 'wallets/lnd'
|
export * from 'wallets/lnd'
|
||||||
|
|
||||||
|
@ -12,11 +14,13 @@ export const createInvoice = async (
|
||||||
{ cert, macaroon, socket }
|
{ cert, macaroon, socket }
|
||||||
) => {
|
) => {
|
||||||
try {
|
try {
|
||||||
|
const isOnion = TOR_REGEXP.test(socket)
|
||||||
|
|
||||||
const { lnd } = await authenticatedLndGrpc({
|
const { lnd } = await authenticatedLndGrpc({
|
||||||
cert,
|
cert,
|
||||||
macaroon,
|
macaroon,
|
||||||
socket
|
socket
|
||||||
})
|
}, isOnion)
|
||||||
|
|
||||||
const invoice = await lndCreateInvoice({
|
const invoice = await lndCreateInvoice({
|
||||||
lnd,
|
lnd,
|
||||||
|
|
|
@ -16,7 +16,7 @@ import { timestampItem } from './ots.js'
|
||||||
import { computeStreaks, checkStreak } from './streak.js'
|
import { computeStreaks, checkStreak } from './streak.js'
|
||||||
import { nip57 } from './nostr.js'
|
import { nip57 } from './nostr.js'
|
||||||
import fetch from 'cross-fetch'
|
import fetch from 'cross-fetch'
|
||||||
import { authenticatedLndGrpc } from 'ln-service'
|
import { authenticatedLndGrpc } from '@/lib/lnd'
|
||||||
import { views, rankViews } from './views.js'
|
import { views, rankViews } from './views.js'
|
||||||
import { imgproxy } from './imgproxy.js'
|
import { imgproxy } from './imgproxy.js'
|
||||||
import { deleteItem } from './ephemeralItems.js'
|
import { deleteItem } from './ephemeralItems.js'
|
||||||
|
|
Loading…
Reference in New Issue