Github: https://github.com/Q-Vault/qvault
Website (under construction): https:qvault.io
Q Vault is a new open source password manager built using ...
For further actions, you may consider blocking this person and/or reporting abuse
Also, what's up with this?
I don't think that a hardcoded salt is production ready ...
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 alsopassword
, 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.
What library/libraries does it use for cryptography?
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.
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.
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.
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?
But that's no excuse for reusing salts.
You might as well not use a salt.
I've tried searching, but I can't seem to find anything about box-level encryption. What do you mean?
Okay. It makes sense. Why do you want AES-256 in GCM mode? And why Scrypt?
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.
Libsodium is a cryptography library that's easy to use. You should be using that instead of what you're doing.
Oh okay, that makes sense now. I thought you were using a salt legitimately.
Libsodium isn't "training wheels". It's a production ready solution that most people should be using.