NWS - enable TCP on Nostr
Go to file
asmogo ce641ae704
Merge pull request #25 from davidcaseria/cert-dns-name
Add domain to certificate DNS name
2024-07-29 15:33:47 +02:00
.github update go version for github actions 2024-07-25 18:52:25 +02:00
cmd cleanup 2024-07-28 19:56:42 +02:00
config Added new MessageType for ConnectReverse. 2024-07-26 12:37:11 +02:00
exit Add domain to certificate DNS name 2024-07-29 09:11:06 -04:00
netstr reintroduce domain validation for .nostr domains 2024-07-29 10:12:55 +02:00
protocol Add domain parsing for .nostr addresses 2024-07-27 21:48:16 +02:00
proxy Added new MessageType for ConnectReverse. 2024-07-26 12:37:11 +02:00
socks5 restructure stuff 2024-07-26 21:21:50 +02:00
.gitignore Initial commit 2024-07-22 23:00:21 +02:00
coverage.txt updated readme 2024-07-24 22:45:41 +02:00
docker-compose.yaml updated compose build 2024-07-25 19:51:08 +02:00
go.mod Add EntryConfig to New function and update dependencies 2024-07-26 19:37:34 +02:00
go.sum Add EntryConfig to New function and update dependencies 2024-07-26 19:37:34 +02:00
LICENSE Initial commit 2024-07-22 23:00:21 +02:00
nws.png Initial commit 2024-07-22 23:00:21 +02:00
README.md readme 2024-07-28 20:21:46 +02:00

Nostr Web Services (NWS)

NWS replaces the IP layer in TCP transport using Nostr, enabling a secure connection between clients and backend services.

Exit node domain names make private services accessible to entry nodes.

Prerequisites

  • A list of Nostr relays that the exit node is connected to.
  • The Nostr private key of the exit node.

Overview

NWS main components

  1. Exit node: It is a TCP reverse proxy that listens for incoming Nostr subscriptions and forwards the payload to your designated backend service.
  2. Entry node: It forwards tcp packets to the exit node using a SOCKS proxy and creates encrypted events for the exit node.

NWS domain names

There are two types of domain names resolved by NWS entry nodes:

  1. .nostr domains have base32 encoded public key hostnames and base32 encoded relays as subdomains.
  2. nprofiles are combinations of a Nostr public key and multiple relays.

Both types of domains will be generated and printed in the console on startup

Quickstart

Running NWS using Docker is recommended. For instructions on running NWS on your local machine, refer to the Build from source section.

Using Docker-Compose

Please navigate to the docker-compose.yaml file and set NOSTR_PRIVATE_KEY to your own private key. Leaving it empty will generate a new private key on startup.

To set up using Docker Compose, run the following command:

docker compose up -d --build

This will start an example environment, including:

You can run the following commands to receive your NWS domain:

docker logs exit-https 2>&1 | awk -F'domain=' '{if ($2) print $2}' | awk '{print $1}'
docker logs exit 2>&1 | awk -F'domain=' '{if ($2) print $2}' | awk '{print $1}`

Sending requests to the entry node

With the log information from the previous step, you can use the following command to send a request to the exit node domain:

curl -v -x socks5h://localhost:8882  http://"$(docker logs exit 2>&1 | awk -F'domain=' '{if ($2) print $2}' | awk '{print $1}' | tail -n 1)"/v1/info --insecure

If the exit node supports TLS, you can choose to connect using https scheme

curl -v -x socks5h://localhost:8882  https://"$(docker logs exit-https 2>&1 | awk -F'domain=' '{if ($2) print $2}' | awk '{print $1}' | tail -n 1)"/v1/info --insecure

When using https, the entry node can be used as a service, since the operator will not be able to see the request data.

Build from source

The exit node must be set up to make your services reachable via Nostr.

Exit node

Configuration should be completed using environment variables. Alternatively, you can create a .env file in the current working directory with the following content:

NOSTR_RELAYS = 'ws://localhost:6666;wss://relay.domain.com'
NOSTR_PRIVATE_KEY = "EXITPRIVATEHEX"
BACKEND_HOST = 'localhost:3338'
  • NOSTR_RELAYS: A list of nostr relays to publish events to. Will only be used if there was no relay data in the request.
  • NOSTR_PRIVATE_KEY: The private key to sign the events
  • BACKEND_HOST: The host of the backend to forward requests to

To start the exit node, use this command:

go run cmd/exit/exit.go

If your backend services support TLS, your service can now start using TLS encryption through a publicly available entry node.


Entry node

To run an entry node for accessing NWS services behind exit nodes, use the following command:

go run cmd/entry/main.go

If you don't want to use the PUBLIC_ADDRESS feature, no further configuration is needed.

PUBLIC_ADDRESS = '<public_ip>:<port>'
  • PUBLIC_ADDRESS: This can be set if the entry node is publicly available. When set, the entry node will additionally bind to this address. Exit node discovery will still be done using Nostr. Once a connection is established, this public address will be used to transmit further data.
  • NOSTR_RELAYS: A list of nostr relays to publish events to. Will only be used if there was no relay data in the request.