-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Hash phone number #7
Comments
Using a salt would increase the "strength" of the hash. However there are two situations where the phone number is used in different contexts:
Therefore, a salt needs to be based on information available to both Adam and Eve. In this case, other than the phone number the name of the user could be shared. However, if Eve has named Adam something else in her phonebook, e.g. "Adam at Work", then a common salt can not be generated. |
A secret salt could be stored on the server to increase the strength of the hash. Then every phone number would be hashed like
This solution would be as secure as the salt is secret. |
Another solution would be to base the salt on information about the phone number (as the phone number of Adam is the only information available to both Adam and Eve). For example, if the country code of the phone number can be retrieved, the salt could be based on that.
This could then be combined with a secret salt, e.g:
Would this approach make it difficult enough to generate lookup tables so that the hashes can be stored on the back-end without the risk of exposing users phone numbers? |
If you base the salt on a part of the phone number (e.g. country code), then it is no better than just the phone number. To add any value, it must be independent from the phone number, e.g. the name (which causes problems as you mentioned above). You can have a secret salt (one salt per phone number, same as for passwords), then you'd protect the list of registered phone numbers. But each user must submit the contact list in plaintext, as it's only the server who has the salts required for the hashing. This is not an easily solved problem, see Difficulty of Private Contact Discovery. But we're working on it ;-) |
Just to try to think of other solutions: why do you want to allow anyone with your phone number to send stuff to your reading lists? Do you want anyone with your email address to put emails in your inbox? (I'm thinking of all those emails that you now have to filter to your spam folder, which is a bad solution already from the start.) A solution for this would be a secure and usable identity manager which is fully decentralized. I think that one of the main problems facing Signal (in the above article) is that it's a centralized solution. The same applies to your thinking above, it's a centralized solution. I'll get back to you with a suggestion. |
You can probably change the title of this issue to "contact discovery". |
Note to self - look into this for hashing: https://github.com/jdconley/pwhaas |
I looked at this one only quickly. Interesting idea, but I'm not
entirely comfortable with it yet.
…On Sun 04 Jun 2017 14:37:16 GMT, Oscar Björkman wrote:
Note to self - look into this for hashing: https://github.com/jdconley/pwhaas
--
You are receiving this because you commented.
Reply to this email directly or view it on GitHub:
#7 (comment)
|
And it will not help you for the case of phone numbers: there are too few of them, so brute force works. |
https://github.com/SilentCircle/contact-discovery Interesting read, needs further investigation if this would be suitable for Flowlist. |
SolutionThe solution I will move forward with is to not hash the phone numbers of users. Instead Flowlist will limit the phone numbers that are transferred from the contact book to only those necessary. Any transfer of phone numbers is done over HTTPS. DiscussionPros
Cons
FlowSign up
Sharing links
Getting links
Flowlist WebAt first Adam should be able to login and see his lists by verifying his phone number. Photos and names will not be available for the senders of the links, neither will Adam be able to send links using the web version. Adam should be able to either
|
To allow the user to see which contacts are also users of Flowlist contact phone numbers needs to be stored on the backend along with a user id.
To respect user privacy and avoid leaking sensitive data, the phone number of a user should not be stored in a readable format on the back-end. A solution would be to hash the phone number.
However, as phone numbers follow a limited pattern, lookup tables can easily be generated.
How can phone numbers be hashed to reduce the risk of an attacker resolving the phone number behind the hash?
The text was updated successfully, but these errors were encountered: