🌟 If you find this project useful, please consider giving it a star! 🌟
Try cloud version 🔥 • Website 🌐 • Documentation 📚 • Self-host instructions ⚙️
Open-source password and (email) alias manager
AliasVault is an end-to-end encrypted password and (email) alias manager that protects your privacy by creating alternative identities, passwords and email addresses for every website you use. The core of AliasVault is built with C# ASP.NET Blazor WASM technology. AliasVault can be self-hosted on your own server with Docker.
- Zero-knowledge architecture: All data is end-to-end encrypted on the client and stored in encrypted state on the server. Your master password never leaves your device and the server never has access to your data.
- Built-in email server: AliasVault includes its own email server that allows you to generate virtual email addresses for each alias. Emails sent to these addresses are instantly visible in the AliasVault app.
- Alias generation: Generate aliases and assign them to a website, allowing you to use different email addresses and usernames for each website. Keeping your online identities separate and secure, making it harder for bad actors to link your accounts.
- Open-source: The source code is available on GitHub and can be self-hosted on your own server.
Note: AliasVault is currently in active development and some features may not yet have been (fully) implemented. If you run into any issues, please create an issue on GitHub.
The official cloud version of AliasVault is freely available at app.aliasvault.net. This fully supported platform is always up to date with our latest release. Create an account to protect your privacy today.
To self-host and install AliasVault on your own server, the easiest method is to use the provided install script. This will download the pre-built Docker images and start the containers.
This method uses pre-built Docker images and works on minimal hardware specifications:
- Linux VM with root access (Ubuntu/AlmaLinux recommended) or Raspberry Pi
- 1 vCPU
- 1GB RAM
- 16GB disk space
- Docker installed
# Download install script from latest stable release
curl -o install.sh https://raw.githubusercontent.com/lanedirt/AliasVault/0.11.1/install.sh
# Make install script executable and run it. This will create the .env file, pull the Docker images, and start the AliasVault containers.
chmod +x install.sh
./install.sh install
The install script will output the URL where the app is available. By default this is:
- Client: https://localhost
- Admin portal: https://localhost/admin
Note: If you want to change the default AliasVault ports you can do so in the
.env
file.
For more detailed information about the installation process and other topics, please see the official documentation website:
Here you can also find step-by-step instructions on how to install AliasVault to e.g. Azure, AWS and other popular cloud providers.
AliasVault takes security seriously and implements various measures to protect your data:
- All sensitive user data is encrypted end-to-end using industry-standard encryption algorithms. This includes the complete vault contents and all received emails.
- Your master password never leaves your device.
- Zero-knowledge architecture ensures the server never has access to your unencrypted data
For detailed information about our encryption implementation and security architecture, see the following documents:
AliasVault is under active development with new features being added regularly. We believe in transparency and want to share our vision for the future of the platform. Here's what we've accomplished and what we're working on next:
- Core password & alias management
- End-to-end encryption
- Built-in email server for aliases
- Single-command Docker-based installation
- Browser extensions Chrome + Firefox (#541)
- Add and associate TOTP MFA tokens to credentials (#181)
- Add support for connecting custom user domains to cloud hosted version (#485)
- Import passwords from existing password managers (#542)
- Mobile apps (iOS, Android)
- Team / organization features (sharing passwords/aliases)
- Disposable phone number service
Want to suggest a feature? Join our Discord or create an issue on GitHub.
The following technologies, frameworks and libraries are used in this project:
- C# - A simple, modern, object-oriented, and type-safe programming language.
- ASP.NET Core - An open-source framework for building modern multi-platform web applications.
- Entity Framework Core - Object-relational mapping framework for .NET.
- Blazor WASM - A framework for building interactive web UIs using C# instead of JavaScript. It's a single-page app framework that runs in the browser via WebAssembly.
- PostgreSQL - An open-source object-relational database system used as the database for the server.
- Docker - Used for containerizing the server and client apps.
- SQLite - A C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine. Used as database engine for the encrypted user's vault.
- Tailwind CSS - A utility-first CSS framework for rapidly building custom designs.
- Flowbite - A free and open-source UI component library based on Tailwind CSS.
- Konscious.Security.Cryptography - A .NET library that implements Argon2id, a memory-hard password hashing algorithm.
- SRP.net - SRP6a Secure Remote Password protocol for secure password authentication without sending plaintext passwords over the network.
- Playwright - A Node.js library to automate Chromium, Firefox and WebKit with a single API. Used for end-to-end testing.
- SmtpServer - A SMTP server library for .NET that is used for the virtual email address feature.
- MimeKit - A .NET MIME creation and parser library used for the virtual email address feature.
- StyleCop.Analyzers - Static code analysis tool that enforces style and consistency rules for C# code.
- SonarQube Cloud - A platform for continuous code quality management.