80
Passkeys: A Shattered Dream (fy.blackhats.net.au)
submitted 8 months ago by lemmyreader@lemmy.ml to c/technology@lemmy.ml
top 50 comments
sorted by: hot top controversial new old
[-] jet@hackertalks.com 36 points 8 months ago

If you really want passkeys, put them in a password manager you control. But don't use a platform controlled passkey store, and be very careful with security keys.

Amazing article. Lots of great inside baseball. I'm a big proponent of hardware security keys, the whole pass key thing didn't make sense to me. Especially the resident keys. If you user workflow is terrible, nobody is going to use them. Which is even worse than not existing

[-] Bitrot@lemmy.sdf.org 6 points 8 months ago

The hardware keys are great but so far don’t have enough storage. For example, Yubikey as a second factor dynamically generated its responses, but now that it’s storing them it’s very limited to at most 25. It’s a known issue that will be solved though.

[-] jet@hackertalks.com 3 points 8 months ago

Fido2 solves this already ...

[-] Bitrot@lemmy.sdf.org 1 points 8 months ago* (last edited 8 months ago)

Passkeys are FIDO2. The issue is the tokens don’t have much storage for them. For passwordless vs use as a second factor, it has to store it instead of dynamically generating a response to a challenge. They are two features of the protocol.

https://www.yubico.com/blog/a-yubico-faq-about-passkeys/

[-] jet@hackertalks.com 3 points 8 months ago

https://developers.yubico.com/Passkeys/Passkey_concepts/Discoverable_vs_non-discoverable_credentials.html

While non-discoverable credentials are not considered passkeys, you should still be aware of them as there are still a number of valid scenarios where your application will need to support the use of them - especially as they are still valid WebAuthn credentials. These are credentials that cannot be generically invoked by a relying party. Instead a user will need to prompt the relying party with a username (user handle) to have the application provide a list of credential IDs to denote which credential(s) can be leveraged for authentication.

Fido2 webauthn non-discoverable credentials are completely unlimited. Because the private key is on the yubikey directly. The only downside of this, is you have to type in your username first, but I think that's an upside personally. I do not want anybody who compels disclosure of my hardware security key, to see all the accounts on it.

[-] Bitrot@lemmy.sdf.org 2 points 8 months ago* (last edited 8 months ago)

Are your non-discoverable credentials also locked on the key, or can someone who knows your handle and possesses your key access your accounts? Online usernames are not well protected, I’d rather my key lock out after a few failed attempts to access it.

[-] jet@hackertalks.com 2 points 8 months ago* (last edited 8 months ago)

The non-discoverable keys cannot be removed from the device. The secret is non-transferable.

In the yubikey bio series, this is implemented as a second factor. So you log in, and then present your hardware key as a second factor. You need your fingerprint, the key, your username. Fairly secure.

I think this is a more secure model than pass keys as they're being promoted today

[-] Bitrot@lemmy.sdf.org 1 points 8 months ago* (last edited 8 months ago)

Yes, but do you need to unlock your key to use it? Possession is not enough to access discoverable credentials.

You edited, but I don’t see this as significantly more secure than the Passkeys, and most keys are not the bio series (not that I trust fingerprint readers anyway).

[-] jet@hackertalks.com 1 points 8 months ago

Yes you need to unlock the The hardware key

[-] Bitrot@lemmy.sdf.org 2 points 8 months ago

In that case it does sound better, and many sites using passkeys still have you enter your username first anyway, at least at this point. I don’t know how Android implements it, I think iOS likely supports this use case and know that it also works as a second factor to a password through the same Passkey workflow. Unlike the Yubikey it always stores the key when you register though, even if it isn’t fully passwordless. Unfortunately what’s easy for the consumer will dominate.

[-] jet@hackertalks.com 1 points 8 months ago

I think the argument and the article is users just are going to avoid this whole confusing mess

And I would absolutely like the ability to use hardware key to log into multiple accounts on the same service.

[-] kevincox@lemmy.ml 4 points 8 months ago

My biggest problem with hardware keys are replacement. If I lost one of my keys and get a replacement I would now need to go to a hundred sites and enroll the new key (and remove the old one). Until this workflow is automated I can only reasonably use hardware keys with a small number of "critical" accounts.

So for 99% of sites I'm going to use a synced software key.

[-] jet@hackertalks.com 3 points 8 months ago

That is a reasonable use case for software keys, maybe the sweet spot is using a hardware key to lock your software keys.

[-] umbrella@lemmy.ml 2 points 8 months ago

ive been saying dont trust corpos on this one, and being downvoted every time.

[-] UntitledQuitting@reddthat.com 2 points 8 months ago

I use passkeys stored in my proton pass app when I don’t have my yubikey next to me

[-] CaptObvious@literature.cafe 20 points 8 months ago

I admit that passkeys have never made sense to me. You still have a username and password, but you’ve added a middleman who manages the password. Why not just use a password manager (without MFA, another useless annoyance)?

[-] ShortN0te@lemmy.ml 30 points 8 months ago

Passkeys are not passwords. When you authenticate using passkeys you will proof that you have the secret (passkey), but you will never reveal that secret to the service you are authentication against.

So even if someone is able to steal that package containing the answer, that answer will not be valid a second time.

[-] GammaGames@beehaw.org 1 points 8 months ago

So it’s like a credit card chip?

[-] ShortN0te@lemmy.ml 2 points 8 months ago

Its like the key in the Chip. But yes fundamentally it is like that. Now the Key needs to be stored somewhere safe like in your Phones secure enclave or in the case of your credit card a so called smart card (or sim card etc.)

load more comments (16 replies)
[-] lemmyvore@feddit.nl 7 points 8 months ago

Passkeys are. more similar to TOTP codes than passwords. Everything about passkeys is autogenerated. Browser negotiates with website to generate a key pair that will establish your identity on that site. Every time you "login" they exchange unique autogenerated keys to prove to each other who they are. That's it. You never have to remember anything again and it's impervious to many attacks that affect passwords and 2fa codes.

Where they fucked up is allowing big tech to call the shots so now instead of simply having passkeys in your browser you have to go to a higher authority to have them validated. And goes who that is — Google, Microsoft, Apple. So it's basically gatekeep and you can't touch them without depending on them.

[-] JuxtaposedJaguar@lemmy.ml 1 points 8 months ago* (last edited 8 months ago)

How is that different from mutual TLS authentication?

Edit: It seems like OPAQUE just initiates mutual TLS authentication after the TLS session has already been negotiated with PKI. So it basically just allows websites to design their own login page instead of the one designed by the web browser.

[-] fushuan@lemm.ee 1 points 8 months ago

It's like the initial authentication, where server and clientnexchange a symmetrical key with their asymmetrical keys. The difference is that in that exchange the server and the client meet for the first time whereas the point of pass keys is that once when you were already authenticated, you validated the device or whatever will hold the private key as a valid source, so then when the authentication code gets exchanged, both ends can verify that the other end is who they tell is, and both can verify the other end as valid, and thus that exchange authenticates you because you, in the past, while authenticated, trusted that device as valid.

Technically, yeah, it's an asymmetrical key exchange. Iirc the server sends you a signed certificate and you need to unencrypt itnwithbtheir public key and sign it with your private key, so they can the getnit back and ensure that it was you who signed it, using your public key to check the validity of whatever was sent.

I don't know enough to be 100% corrextbon the details, but the idea is that it's an interaction between asymmetrical keys.

Soporta like how we use keysbto authenticate through github through SSL, but with an extra level of security where the server validates a key in a single endpoint, not wherever that private key would be held (like with SSL)

[-] intrepid@lemmy.ca 14 points 8 months ago

With this much complexity, why not just use TLS client certificates without PKI and managed by a password manager?

[-] Bitrot@lemmy.sdf.org 2 points 8 months ago

Much of the complexity described here comes from the question “which password manager?”

[-] kevincox@lemmy.ml 12 points 8 months ago

I also find passkeys to be underwhelming and hope they don't catch on. It seems like a huge mire of complexity for very little gain. It seems like there are two main goals here:

  1. Don't sent secrets to the sever.
  2. Stop phishing.

Both great goals. However I wonder if we threw out the baby with the bathwater with passkeys.

A password manager is already a huge step to blocking phishing, because if the password doesn't auto-fill you get super suspicious. If you push your user to randomly generate their passwords then they also don't remember them so would have to look them up, then copy them over. If you are worried about users who are a risk to themselves you can make the route to extract a password from the password manager as complicated as you like.

As for not sending secrets to the server I think using a PAKE would have been a great option. If this was paired in a browser-integrated password manager it could be very secure. Think about some type of form field that can be filled with a password that isn't accessible to the page itself. The browser would then tag the password as PAKE and never expose it to the page again.

Another cool think able PAKE is that they can also authenticate the server. TLS-integrated SRP was very cool like this as you could have a self-signed certificate but verify it by entering your username and password. The UX may not have been good enough for public sites but it was an amazingly easy and secure option for private sites. This would actually be more secure than a PKI signed certificate as you aren't risking CA compromise. That being said integrating this with browsers with good UX may be quite difficult. I would love to see it.

But the biggest thing we lost was understandability. Even my grandmother understood what a password is. She knew how to back it up, how to transfer it to a new device. She could use it in two different browsers without setting up some multi-browser sync tool. She could write it in a notebook and log in at the library computer.

I really think that we should have just iterated on passwords. Switch to a PAKE and keep improving password-manager UX and pushing most users to auto-generated passwords. So much was lost by switching to a system that most users don't understand.

I wrote a blog about this a while ago. https://kevincox.ca/2022/04/07/passwords/

[-] lemmyreader@lemmy.ml 5 points 8 months ago

Glad to see another person who is not keen on the passkeys. I have the feeling it is being hyped and perhaps without good reasons. Therefore I was glad to share this blog post when I saw it on Mastodon. btw, the blog post author turns out to be the software developer of similar software like Authentik and Keycloak. In other words, not just the average Linux user :)

I really think that we should have just iterated on passwords. Switch to a PAKE and keep improving password-manager UX and pushing most users to auto-generated passwords. So much was lost by switching to a system that most users don’t understand.

When I search with a search engine for PAKE I don't find anything useful. Got a link ?

I like your reasoning about just using passwords. However, my experience is that a scary amount of users are using the same rather weak password for lots of different accounts. And a still scary amount of users does get tricked into phishing emails. What I like for myself is have a bunch of security keys and use them as much as possible for important logins.Some applications allow for five different security keys to be configured.And this could theoretically also be a way to use 2FA within teams. One team person does the login, adds a key, then let's the second team member put in their key and so on.

I wrote a blog about this a while ago. https://kevincox.ca/2022/04/07/passwords/

Thanks. I see you shared it two years ago on Lobsters and got a fair amount of comments. 👍

[-] kevincox@lemmy.ml 2 points 8 months ago

https://en.wikipedia.org/wiki/Password-authenticated_key_agreement

Cloudflare also had a fairly good post a while ago about a newer PAKE algorithm: https://blog.cloudflare.com/opaque-oblivious-passwords

a scary amount of users are using the same rather weak password for lots of different accounts

This is true, but you can force them to use a random password just as easily as you can force them to use a randomly generated key. The end UX can look basically identical if you want it to. My point is that this is basically a UX problem. Instead of just making the change we are inventing this new protocol to shuffle along a UX change at the same time. Maybe part of this is because the change has major unaddressed downsides that would be too obvious to slip by if made as an incremental upgrade to passwords.

One team person does the login, adds a key, then let’s the second team member put in their key and so on.

There is no reason you can't have multiple passwords associated with an account.

[-] fushuan@lemm.ee 1 points 8 months ago

But... PAKE is used as a method for ongoing exchange of messages, you wouldnt avoid using a password when authenticating, which is the whole point of this debacle.

In really don't see it that complex, in my last job IT installed a passkey in my laptop, which then Microsoft used to login and thorough its SSO, I just stopped using passwords altogether after logging into my PC itself. This is way more secure for the average Joe than having 5 postists with passwords pasted in the sides of the monitors. Yes this is way more common then you think, there's a reason passwords need to be rotated all the freaking time.

Once rolled out, workers didn't have to do anything to authenticate, as long as they were using the work laptop the company assumed that the used was the one using it, since the laptop was registered to the user, and it was way more comfortable.

It's not really that hard to explain to people. Sending passwords is insecure because if an attacker gets the password, you lost. With passkeys, once you set it up, google/microsoft/pepapig.com will send a request to authenticate to your phone, where you will just say "yes" and they will talk with each other to give you access. If an attacker gets hold of that message, it doesn't get anything of value because each time pepwpig.com and your phone talk with each other, they say different stuff and the attacker would just have yesterday's responses, so they lose.

Old people won't adopt it unless forced, just like they adopted special passwords by adding 1 and * to whatever stupid word they use and writing it next to their work monitor, in the office. They just won't. Either IT automates everything for them or anything we develop will get completely bypassed.

[-] kevincox@lemmy.ml 2 points 8 months ago

But… PAKE is used as a method for ongoing exchange of messages

I don't know what you mean.

In really don’t see it that complex, in my last job IT installed a passkey in my laptop

They can also install a randomly generated password just as easily.

Sending passwords is insecure because if an attacker gets the password, you lost

That is why you use a PAKE, you don't send the password.

Old people won’t adopt it unless forced

They also won't adopt passkeys unless forced. What is the difference?

[-] lemmyreader@lemmy.ml 0 points 8 months ago

This PAKE post by Cloudflare is way over my head, but very good to see that new things are explored to make security really better.

[-] haui_lemmy@lemmy.giftedmc.com 7 points 8 months ago

Not sure if this applies but incidentally I changed my otp manager from microsoft to vaultwarden today. Adding security keys in the process is mostly two additional clicks. Of the 20 accounts I migrated, only about 7 had the option and only with one it was more work than adding totp.

[-] thegreekgeek@midwest.social 3 points 8 months ago

Yeah I use bitwarden and it was pretty panless. My only issue was on github the addon didn't pick up on the passkey initially, had to make a new one.

[-] haui_lemmy@lemmy.giftedmc.com 2 points 8 months ago

Happy to hear it works for others as well. :)

[-] anas@lemmy.world 1 points 8 months ago

Doesn’t using the same service for password management and OTP defeat the purpose of 2FA?

[-] haui_lemmy@lemmy.giftedmc.com 1 points 8 months ago

Its a pretty tough decision what to use for this imo since technically, you‘re right. Then again, you already have to log into your os and unlock the password safe to get the passwords or the otps.

The reason why mfa is done is if your password leaks you are not completely effed. You can obviously use a second selfhosted service with a different password but chances are most people would rather use something easier.

Also, passkeys work the same way. They work if you are logged into a device. That way you get no additional password except you can only use it from the device in question.

load more comments
view more: next ›
this post was submitted on 26 Apr 2024
80 points (88.5% liked)

Technology

35203 readers
125 users here now

This is the official technology community of Lemmy.ml for all news related to creation and use of technology, and to facilitate civil, meaningful discussion around it.


Ask in DM before posting product reviews or ads. All such posts otherwise are subject to removal.


Rules:

1: All Lemmy rules apply

2: Do not post low effort posts

3: NEVER post naziped*gore stuff

4: Always post article URLs or their archived version URLs as sources, NOT screenshots. Help the blind users.

5: personal rants of Big Tech CEOs like Elon Musk are unwelcome (does not include posts about their companies affecting wide range of people)

6: no advertisement posts unless verified as legitimate and non-exploitative/non-consumerist

7: crypto related posts, unless essential, are disallowed

founded 5 years ago
MODERATORS