/eva

✴️ free, anonymous password manager with e2e encryption on top of SRP protocol. Wault believes in the value of anonymity. The less your password manager knows about you, the safer is your data. Wault does not ask for your email, phone number, or any other personal information.

Primary LanguageJavaScriptGNU Affero General Public License v3.0AGPL-3.0

eva

Test

English, Chinese

To avoid storing data on the server, the Wault password manager encrypts and decrypts data inside the browser. The keys for all encryption processes are derived from the password, which is never sent to the server.

Encryption primitives & protocols

  • AES (GCM mode)
  • RSA (OAEP mode)
  • HMAC
  • PBKDF2
  • SRP6a (secure remote password)

In simple terms, Wault password manager is an online service that knows nothing about its users. Wault looks like an ordinary web application, but hides a powerful cryptographic mechanism entirely created and executed in your browser.

Based on this idea, we developed and implemented a web application architecture that supports your privacy. The main idea was to create a trust-free service, where users could trust the data within the browser, regardless of external sources.

Wault password manager

Docker setup

The simplest docker installation (implies you are using local postgres), looking the following. You have to create an empty database psql -c 'CREATE DATABASE alice' first.

docker run --rm -e PG_DSN="postgres://${USER}@host.docker.internal:5432/alice?sslmode=disable&timezone=utc" -p 3000:3000 shlima/wault 

Production ready setup should be like this one. Please provide your own random keys.

  • SSE_KEY for server side encryption
  • JWT_KEY for signing JWT cookies
  • COOKIE_SECURE set to true if you run wault instance behind the HTTPS
  • COOKIE_DOMAIN set a domain name if you run wault instance within your domain
docker run --rm \
-e PG_DSN="postgres://${USER}@host.docker.internal:5432/alice?sslmode=disable&timezone=utc" \
-e SSE_KEY=bf02ee811878d6cd9eebb823e54d2bdc318b4fc676df9c3f709f8c9c6ca8fff0 \
-e JWT_KEY=7cfa6c528a3060810ae8337382b99a9eaaf305a8055d4739df8312155a0d93d8 \
-e COOKIE_SECURE=false \
-e LOCALE=en \
-e PRODUCTION=true \
-p 3000:3000 \
shlima/wault

Development

First, run the backend (called alice), you may use the Docker image to achieve that:

docker run -p 8080:8080 -e PG_DSN="postgres://..." --rm ghcr.io/wault-pw/alice goose up # run migrations
docker run -p 8080:8080 -e PG_DSN="postgres://..." --rm ghcr.io/wault-pw/alice server
yarn dev

Wault: encrypted, anon. password manager - SRP6a, AES, RSA, HMAC | Product Hunt