Store ID hashes separate from VRC accounts, with no association.
Zеkk
In the FAQ (https://ask.vrchat.com/t/age-verification-faq/28458) it is stated the purpose of storing an ID hash is to:
---
Detect duplicate IDs: When someone submits a verification, we compare it against our existing hashes. If we find a match, we know that ID has been used before and can reject the verification.
Enforce bans: We can check if an ID was previously associated with a banned account, preventing banned users from verifying new accounts with the same ID.
Enable multiple accounts: We can allow users to have more than one verified account using the same ID. Previously, this would have required keeping your full ID data with Persona. While this is not planned for initial launch, we are considering the feedback that you have given us.
---
This indicates that you will be storing some sort of mapping between the hashed data (which you have not clarified what data is being used in this hash, please do so) and a VRC account. This is bad. While hashing data with a salt is a one way action, it is brute force-able. With time and resources (the amount of which decreases as technology progresses) these hashes can be cracked. Salting makes this not viable on a wide scale (cracking every hash in a leak at once), but targeted cracking is still very possible.
If this database of hashes leaks (assuming the pepper leaks along with it), anyone with a grudge can dedicate time to crack a specific hash for the user that they have a grudge against. Likewise, high profile users like creators/vtubers are at high risk due to simply being more known.
There is also not a ton of actual information stored on the ID itself, and much of it is in predictable formats (ie: dates, names, address, etc). Not to mention that supporting every ID type likely means that only a subset of this information will actually be used for the hash. This lowers the entropy of the input to the hashing function making it easier to crack a specific hash. Storing more sensitive data to increase the entropy is a cyclical loop, in that it presents more risk in the event of the hash being cracked.
Storing an association between the hashed data and a VRChat account is not required to do 2 of the 3 goals of storing the hash:
---
- Detect duplicate IDs: No association is required to do this, you simple store the hash itself, and check against all hashes for each new ID added. You would have to do this anyway.
- Enable Multiple Accounts: If you choose to do this, you can simply stop checking against your hash store, delete hashes you have, and stop storing new hashes. Alternatively, If you would like to limit the number of accounts that can be used under one ID, you can continue the same way, but also store a value with the hash that represents the number of times it has been used to verify.
- Enforce bans: This one does not have a solution. However, this relies on VRChat having already allowed users to verify multiple accounts with one ID. This also assumes that the person is verifying under their own identity to begin with, which is made less likely by the previous sentence. Abusers of this system would also likely rack up many verifications/accounts as they would have to keep verifying as they got banned over and over. If a limit is in place for how many accounts can be verified under one ID, it would be reached. If there is no limit, that number would still climb higher than a normal user of the platform, warranting further investigation.
---
Overall, if any sensitive information is planned to be used to generate the hash, IE: Name, ID#, address. Then I personally think storing the hash with an association to a VRChat account is dangerous, and should not be done. It is not really required to do the main purpose of storing a hash in the first place, preventing ID reuse, and increases risk to users in the event that the hashes are leaked.
If no link between a specific VRChat account and their hashed private information is stored, then no individual VRChat user is identifiable.
Log In
Chirping_Cat
This is currently in Beta, and I think VRChat is still working out the final implementation. Personally, I understand why they need to store the hash—for both current Beta needs and potential future use cases.
There may also be legal considerations where retaining the hash is beneficial. I don't think anyone benefits from an age-verification system that has in-built repudiation features; Those features already exist by way of hashing, but removing the link all together means even if you knew the ID used, you could never prove they used it, or prove they verified themselves.
That said, there are technical controls they could implement to further mitigate risks. For example, increasing the number of iterations in the hashing algorithm to a computationally significant level would greatly enhance security. I’m confident these kinds of measures are already in place or under consideration.
ᴋᴀᴡᴀ
That could be a good compromise to be proof against possible leaks.
But we still required to trust that they implement this properly.
Zеkk
ᴋᴀᴡᴀ The reality is that this is just a risk that needs to be taken if you want to use the system.
No amount of feedback about design can defeat improperly implementing that design. We just have to trust. Which I something I am personally willing to do if the design looks solid.