HAVEN (High Availability Vault for Events on Nostr) is the most sovereign personal relay for the Nostr protocol, for storing and backing up sensitive notes like eCash, private chats and drafts. It is a relay that is not so dumb, with features like web of trust, inbox relay, cloud backups, blastr and the ability to import old notes. It even includes it's own blossom media server!
Private Relay: This relay is only accessible by the owner of the relay. It is used for drafts, ecash and other private notes that nobody can read or write to. It is protected by Auth.
Chat Relay: This relay is used to contact the owner by DM. Only people in the web of trust can interact with this relay, protected by Auth. It only accepts encrypted DMs and group chat kinds.
Inbox Relay: This relay is where the owner of the relay reads from. Send your zaps, reactions and replies to this relay when you're tagging the owner. You can also pull notes from this relay if you want notes where the owner is tagged. This relay automatically pulls notes from other relays. Only notes where the owner is tagged will be accepted to this relay.
Outbox Relay: This relay is where the owner's notes all live and are publicly accessible. You can import all your old notes to this relay. All notes sent to this relay are blasted to other relays. Only the owner can send to this relay, but anyone can read.
Blossom Media Server: This relay also includes a media server for hosting images and videos. You can upload images and videos to this relay and get a link to share them. Only the relay owner can upload to this relay, but anyone can view the images and videos.
Web of Trust: Protected from DM and Inbox spam by using a web of trust.
Inbox Relay: Notes are pulled from other relays and stored in the inbox relay.
Cloud Backups: Notes are backed up in the cloud and can be restored if the relay is lost.
Blastr: Notes sent to the outbox are also blasted to other relays.
Import Old Notes: Import your old notes and notes you're tagged in from other relays.
-
Go: Ensure you have Go installed on your system. You can download it from here.
sudo apt update #Update Package List sudo apt install snapd #install snapd to get a newer version of Go sudo snap install go --classic #Install Go go version #check if go was installed correctly
-
Build Essentials: If you're using Linux, you may need to install build essentials. You can do this by running
sudo apt install build-essential
.
Follow these steps to get the Haven Relay running on your local machine:
git clone https://github.com/bitvora/haven.git
cd haven
You'll need to create an .env
file based on the example provided in the repository.
cp .env.example .env
Open the .env
file and set the necessary environment variables.
Copy the example relays JSON files for your seed and blastr relays:
cp relays_import.example.json relays_import.json
cp relays_blastr.example.json relays_blastr.json
The JSON should contain an array of relay URLs, which default to wss:// if you don't explicitly specify the protocol.
Run the following command to build the relay:
go build
To have the relay run as a service, create a systemd unit file. Make sure to limit the memory usage to less than your system's total memory to prevent the relay from crashing the system.
and Replace the values for ExecStart
and WorkingDirectory
with the actual paths where you cloned the repository and stored the .env
file.
- Create the file:
sudo nano /etc/systemd/system/haven.service
- Add the following contents:
[Unit]
Description=Haven Relay
After=network.target
[Service]
ExecStart=/home/ubuntu/haven/haven #Edit path to point to the path of where the haven git was pulled
WorkingDirectory=/home/ubuntu/haven #Edit path to point to the path of where the haven git was pulled
MemoryLimit=1000M # Example, Limit memory usage to 1000 MB | Edit this to fit your machine
Restart=always
[Install]
WantedBy=multi-user.target
- Reload systemd to recognize the new service:
sudo systemctl daemon-reload
- Start the service:
sudo systemctl start haven
- (Optional) Enable the service to start on boot:
sudo systemctl enable haven
To have a domain name (example: relay.domain.com) point to your machine, you will need to setup an nginx.
- Install nginx on your relay:
sudo apt-get update
sudo apt-get install nginx
-
Remove default config:
sudo rm -rf /etc/nginx/sites-available/default
-
Create new default config:
sudo nano /etc/nginx/sites-available/default
-
Add new reverse proxy config by adding the following configuration to your nginx configuration file:
server {
listen 80;
server_name yourdomain.com;
location / {
proxy_pass http://localhost:3355;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
Replace yourdomain.com
with your actual domain name.
After adding the configuration, restart nginx:
sudo systemctl restart nginx
If you want to serve the relay over HTTPS, you can use Certbot to generate an SSL certificate.
sudo apt-get update
sudo apt-get install certbot python3-certbot-nginx
After installing Certbot, run the following command to generate an SSL certificate:
sudo certbot --nginx
Follow the instructions to generate the certificate.
Note: Command will fail if the Domain you added to nginx is not yet pointing at your machine's IP address. This is done by adding an A record subdomain pointing to your IP address through your DNS recrods Manager.
If you want to import your old notes and notes you're tagged in from other relays, run the following command:
sudo systemctl stop haven
./haven --import
sudo systemctl start haven
Once everything is set up, the relay will be running on localhost:3355
with the following endpoints:
localhost:3355
(outbox and Blossom server)localhost:3355/private
localhost:3355/chat
localhost:3355/inbox
Haven currently supports BadgerDB and LMDB as embedded databases, meaning no external database is required.
By default, Haven uses BadgerDB. To switch to LMDB, set the DB_ENGINE
environment variable to lmdb
in the .env
file.
LMDB can be faster than BadgerDB but performs best with NVMe drives and may require fine-tuning based on factors such as database size, operating system, file system, and hardware.
For instance, there is no one-size-fits-all value for LMDB’s map size. Windows and macOS users, in particular, may need
to adjust the LMDB_MAPSIZE
environment variable to a value lower than the available free disk space if the default
value of 273 GB is too high. Otherwise, Haven will fail to bootstrap. Users with large databases may also need to
increase the LMDB_MAPSIZE
value above the default. On most systems, the default value should work fine.
Despite the large default value, on most modern systems LMDB will only use the disk space it needs. The map size simply defines an upper limit for the database size. For more information about LMDB’s map size, refer to the LMDB documentation.
The outbox relay also functions as a media server for hosting images and videos. You can upload media files to the relay and obtain a shareable link.
Only the relay owner has upload permissions to the media server, but anyone can view the hosted images and videos.
Media files are stored in the file system based on the BLOSSOM_PATH
environment variable set in the .env
file. The default path is ./blossom
.
The relay automatically backs up your database to a cloud provider of your choice.
To back up your database to AWS, you'll need to first install and configure the awscli. You can do this by running the following commands:
sudo python3 -m pip install awscli
aws configure
After configuring the awscli, you can set the following environment variables in your .env
file:
AWS_ACCESS_KEY_ID=your_access_key_id
AWS_SECRET_ACCESS_KEY=your_secret_access_key
AWS_REGION=your_region
AWS_BUCKET=your_bucket
Replace your_access_key_id
, your_secret_access_key
, your_region
, and your_bucket
with your actual AWS credentials.
To back up your database to GCP, you'll need set up Application Default Credentials (ADC). There are many ways to do so and it varies on the environment you're running the relay on. Check out the official documentation for more information.
After authenticating to GCP, set the environment variable below in your .env
file:
GCP_BUCKET_NAME="backups"
Replace the name of the bucket accordingly.
This project is licensed under the MIT License.