DEV Community

Cover image for Q Vault: An open source secret manager

Q Vault: An open source secret manager

Lane Wagner on May 20, 2019

Github: https://github.com/Q-Vault/qvault Website (under construction): https:qvault.io Q Vault is a new open source password manager built using ...
Collapse
 
tarialfaro profile image
Tari R. Alfaro

Also, what's up with this?

I don't think that a hardcoded salt is production ready ...

 
nathilia_pierce profile image
Nathilia Pierce • Edited

Actually, I disagree, salts are used to prevent rainbow tables/pre computed KDFs, and it's a standard that's highly recommended. You can store the salt with the database. KeePass uses a random salt.

For example, if an attacker pre computed password, and tried it on another user's machine if they're lucky their password is also password, and the database decrypts. This wouldn't happen if you used salts.

Just because the KDF isn't stored, doesn't mean you can't do rainbow tables.

Collapse
 
tarialfaro profile image
Tari R. Alfaro

What library/libraries does it use for cryptography?

Collapse
 
tarialfaro profile image
Tari R. Alfaro

2) It's debatable.

3) It is not the password manager's job to sync files. Let the user deal with that. Save it to a file and call it that. Stop trying to do everything. Do one thing, and do it well.

Collapse
 
tarialfaro profile image
Tari R. Alfaro • Edited

I guess it's fine to have a built-in syncing feature, but it divides your attention. You should be focusing on securing the secrets, rather than syncing files and checking for conflicts.

Users could use NextCloud, DropBox, Syncthing, etc. There are already existing solutions. Just sync the file and let those solutions handle conflicts.

 
nathilia_pierce profile image
Nathilia Pierce

I agree with both of you, however I think having additional features divides your attentions and increases the complexity of the project. Although it's a really good feature for non-tech savvy users.

 
nathilia_pierce profile image
Nathilia Pierce

Oh. That's great to hear! FYI, Qvault looks nice. Do you think you'll be able to do duel encryption via file(s), or physical security keys?

Collapse
 
tarialfaro profile image
Tari R. Alfaro

But that's no excuse for reusing salts.

Thread Thread
 
tarialfaro profile image
Tari R. Alfaro

You might as well not use a salt.

 
nathilia_pierce profile image
Nathilia Pierce

I've tried searching, but I can't seem to find anything about box-level encryption. What do you mean?

 
tarialfaro profile image
Tari R. Alfaro

Okay. It makes sense. Why do you want AES-256 in GCM mode? And why Scrypt?

Collapse
 
tarialfaro profile image
Tari R. Alfaro • Edited

I'd avoid it. It seems really low level from reading some of your source code. Check out a Libsodium port for Node.js.

Using low-level cryptography libraries make it easy to screw up.

 
tarialfaro profile image
Tari R. Alfaro

Libsodium is a cryptography library that's easy to use. You should be using that instead of what you're doing.

 
tarialfaro profile image
Tari R. Alfaro

Oh okay, that makes sense now. I thought you were using a salt legitimately.

 
tarialfaro profile image
Tari R. Alfaro

Libsodium isn't "training wheels". It's a production ready solution that most people should be using.