4

There are questions about using a password only to identify and authenticate a user, rather than an email address or username plus password:

All of those, however, involved public usernames and/or user-set passwords with the potential to reset them. What about random passwords/passphrases that cannot be reset? DuckDuckGo’s Cloud Save made me wonder about this, since it uses the same random passphrases for both identity and authentication, with no email address or username involved.

Let’s say that we are building a service that stores data about its users.

  • If the service randomly generates a passphrase/password (e.g., five random words from a dictionary of 2000 words) for each new user,
  • and every user’s identity is private,
  • and we don’t have to support resetting forgotten passwords (e.g., because we use user passphrases to encrypt all of the user’s stored data with SHA-512 with PBKDF2 or whatever),
  • then what risks are there from using only that random passphrase, rather than also requiring an email address or username to identify the user?
  • (If the new passphrase collides with another user’s during new-user creation, then the service would silently generate another random passphrase and use that instead.)

There is a clear benefit to this: the user would only ever have to type in that passphrase on login, rather than both an email/username and passphrase.

As far as risks go, if an attacker knew that a specific person was a user of our service, the attacker would have to attempt to brute-force the user’s passphrase…which is supposed to be difficult to do in the first place anyway.

However, I can see a risk that the attacker might incidentally happen upon another user’s passphrase while they’re trying to brute-force the first user’s passphrase, gaining access to the other user. But isn’t this a similarly tiny chance anyway? I can see how it would depend on how many users there are registered in the service—if there are a quintillion user accounts, then it’s going to be easier incidentally getting someone’s account by brute-forcing. I don’t know how to calculate this, though.

But that still doesn’t affect the difficulty in breaking encrypted user data if the attacker gains access to the data; its strength would depend on the passphrase and encryption only whether or not an email/username is used for identity.

  • Are there any other risks to using random passphrases for both identity and authentication / data encryption, without emails/usernames?

  • How could one calculate the probability that an attacker will find any user’s passphrase after T tries, given N existing user passphrases and D total theoretical possible passphrases?

user3842252
  • 105
  • 6
  • 1
    From what I can tell, `SELECT` queries are [vulnerable to timing attacks](https://stackoverflow.com/questions/27028284), and it is likely that the same is true for all or most other storage options as well. Currently, this [may or may not matter](https://security.stackexchange.com/questions/111040/), but it's something I would at least consider, in addition to the general impracticality of this approach. As the benefits of the approach are also rather small, I wouldn't use it, but your questions still seem valid to me. – tim Mar 13 '16 at 19:16
  • If you can't reset a password, that means that if a user loses their password, it's game over. Neither them nor anyone else can ever access their data again. That seems awfully risky for most types of services. Users forget their passwords all the time. – Neil Smithline Mar 13 '16 at 22:42

1 Answers1

2

The risks would include the one you mentioned:

the attacker might incidentally happen upon another user’s passphrase while they’re trying to brute-force the first user’s passphrase, gaining access to the other user

For each user that is added to your service, the attacker gets a "free" guess during their attack. In your scenario of an attacker only going for a single user then this doesn't matter - but in the case where an attacker just needs access to one account, every password guess they try is automatically tested against each user account. This works in both an online and offline scenario (the latter might be possible if an attacker gets access to any password hashes that are stored - it's not clear if you're using these or not).

Another drawbacks is that automatic lockout or request throttling of repeated guesses against a particular user is not possible. This is the primary mitigation against password guessing attacks.

if there are a quintillion user accounts, then it’s going to be easier incidentally getting someone’s account by brute-forcing. I don’t know how to calculate this, though.

Quintillion = 1,000,000,000,000,000,000
(World population 7,400,000,000)

Number of permutations = 2000^5 = 32,000,000,000,000,000

Chances that a guessed password (if the wordlist and method is known) 
matches an existing one of the quintillion accounts = 3.2%

Chances if everyone in the world has one account = 
2000^5 / 7,400,000,000 = ~1 in 4.3 million

In order to make these calculations meaningful you would need to know the approximate size of your user base. I doubt it will be as high as in the examples above, but with a quintillion an attacker only needs 32 guesses on average.

SilverlightFox
  • 33,698
  • 6
  • 69
  • 185
  • Sorry so late to the game, stumbled upon this - What is the difference between this, and them guessing the username of a different user? Is it because usernames are not subjected to brute force? Otherwise an argument can be made that the username and password fields in combination, is just a longer password. – Dan Chase Oct 27 '20 at 15:17
  • `Otherwise an argument can be made that the username and password fields in combination, is just a longer password` true on its own, however, a password guessing list will not have usernames in it. Yes, multiple accounts increase the time it would take to run the attack through the full wordlist. Password guessing two accounts takes twice as long as one account. Of course, the attack would end when a valid combination is discovered, but to get to that point it will have taken the attacker twice as long as if they were trying the username alone for this successful outcome. – SilverlightFox Oct 28 '20 at 12:12