Use end-to-end encryption to implement authentication
For normal websites, when you signup, you need to send your email and plaintext password to the backend, then the backend hashes the password and saves it to DB. Google, Facebook, and Apple all do this.
I implement the auth for Watcher37 and Link37 in a different way, in an end-to-end encryption way, with the famous openpgpjs library (used by Proton). This is how it works.
When you signup:
Your device generates a public & private key pair;
Then your device encrypts the private key with your password;
Then your device sends your username, public key, and encrypted private key to the server;
Your password never leaves your device!!!
When you sign in:
Your device makes a request with your username to get your public key, encrypted private key, and a challenge encrypted with your public key;
Your device decrypts the encrypted private key with your password;
Then it uses the decrypted private key to decrypt the challenge, and send the decrypted challenge to the server;
Server checks if the challenge is solved, if yes, it will return an access token and a refresh token back to your device, and you are logged in.
So again, your password never leaves your device!!!
---
The project is open-sourced: https://github.com/penghuili/auth
And try Watcher37 and Link37 to see how it works in action :)