Skip to content

An LNURL server to fetch invoices from a tor hosted Bitcoin lightning node, specifically made for NOSTR zaps

License

Notifications You must be signed in to change notification settings

UTXOnly/zap_server

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

A NIP-57 server that allows you recieve zaps on nostr, forwarded to your lightning node running on Tor. This server allows you to create a Lightning Address by selecting a username and using your own domain. YOu can run this zap server on a $5 a month VPS, I have included some guides in the additional resouces section of this README to help guide users if need be.

The Zapserver can fetch invoices can fetch invoices over tor or Wireguard VPN tunnel. It is strongly recomended to use a Wireguard VPN tunnel to fetch invoices as tor is very slow to return invoices and the person zapping you will probably not wait around for it. You can create a Wireguard VPN tunnel to connect to your tor node by following the wireguard_setup doc.

Zapserver also supports creating kind 9735 zap receipt events and will send that event to all relays listed in the zap request.

Tradeoffs

  • Recieve zaps directly to you lightning node
    • Custody your own sats and don't need to worry about sweeping them from a custodial wallet or getting rug pulled by a custodian
  • Create invoices from your own lightning node and could potentially share information about your node (for example node pubkey, channel balances, UTXOs). See this article for more information about lightning privacy
  • Must maintain sufficent inbound liquidity to recieve zaps and have some path between the sender's wallet and your node
  • Storing an invoice.macaroon on your zap server which can read and create invoices on your node, protect this!

How it works?

zap_server

Prerequisites

  • An Linux server reachable by a public IP (tested on Ubuntu 22.04 amd64 host)
  • Your own domain
  • A Lightning node running LND

What these scripts do

  • Installs all dependencies and configures nginx reverse proxy server
    • This script will overwrite anything in etc/nginx/sites-available/default
    • Uses certbot to get TLS certificate for domain
  • Deploys Flask server to respond to clients with Lightning invoices

What you need to do

  • Getting your LND REST information and invoice.macaroon, this example shows getting this information from a Raspiblitz node.

Screen Recording 2023-11-25 at 12 44 26 AM

Image 2023-11-25 at 12 45 17 AM

  • Clone the repository
git clone https://github.com/UTXOnly/zap_server.git
  • Edit the .env file to include your node and LUD-16 identifier using a command line text editor like nano.
nano .env
  • Example .env file:
LND_ONION_ADDRESS=''#"<YOUR_LND_NODE_ONION_ADDRESS>" For example, xyzdasdsadsa.onion, leave blank if using Wireguard VPN
VPN_HOST=''# <YOUR_HOST_IP> for you VPN client
LND_REST_PORT=8080 #Default LND REST port is 8080, in most cases you can leave this untouched
LND_INVOICE_MACAROON_HEX="<YOUR_LND_INVOICE_HEX_HERE>"
INTERNET_IDENTIFIER="<IDENTIFIER_HERE>" ## Add the value on the left side of your LNURL identifier for example if your LNURL identifier is "[email protected]" you would add "nabismo" here
HEX_PUBKEY='' # <YOUR_NOSTR_HEX_PUBKEY> 
HEX_PRIV_KEY='' #<YOUR_NOSTR_HEX_PRIV_KEY>
DOMAIN="<YOUR_DOMAIN_HERE>" # For example nostpy.lol
CONTACT=<YOUR_EMAIL_ADDRESS> #Enter your email address for the certbot command to get emails about your TLS certificate when it is near expiration
NGINX_FILE_PATH=/etc/nginx/sites-available/default #Leave this untouched
  • You can get the HEX version of your public key from certrain clients and signing extensions

Setup the server

  • Start the CLI menu
python3 menu.py
  • menu.py is the main process used to control the server Screenshot from 2023-11-24 23-49-04

Using the command line interface (CLI)

  • Option 1 runs the server setup script, downloads dependencies, installs and configures the NGINX proxy server
  • Option 2 starts the Flask server to begin responding to clients requests for lightning invoices
  • Option 3 stops the Flask server (Will not respond to requests for invoices)
  • Option 4 exits the CLI menu

Additional Resources

To Do

  • [] Update .env file permissions, potentially encrypt?
  • [] Possibly use Nsecbunker?
  • [] Add UFW firewall rules
  • [] Improve error handling
  • [] Add unit tests
  • Add support for Wireguard VPN tunnel connect method
  • [] Create Docker container deployment option
  • [] Add option to diable the Nginx setup portion ofthe setup script if user is already running Nginx
  • Add response to Nostr client to confirm zap completed succsessfully

Contributing

Anyone is welcome and encourges to contribute! If you want to add feature, feel free to open a pull request.

If you find a bug, please open an issue and include any relevant details, for example:

  • Operating system and version
  • Python version
  • Expected behavior
  • Actual behavior
  • Any logs that might be helpful in troubleshooting

About

An LNURL server to fetch invoices from a tor hosted Bitcoin lightning node, specifically made for NOSTR zaps

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages