Attending AWS re:Invent?Where to find us
Get started
Login
WireGuard is a registered trademark of Jason A. Donenfeld.
© 2024 Tailscale Inc. All rights reserved. Tailscale is a registered trademark of Tailscale Inc.
Blog|June 07, 2023

Tailscale doesn't want your password

alt

Tailscale has never supported password-based authentication. As security-conscious software that connects your private devices across the internet, we had to face a harsh reality: the password is outdated technology that requires kludges to use safely. Passwords must be complex enough that a human cannot remember them and they must not be reused across services, which means we now need software to manage our passwords.

To keep logins sane, Tailscale started by requiring users log in using reasonably well-managed Google and Microsoft auth providers. Over time we expanded our login options to include GitHub, Apple, and custom OIDC providers. Now, we are happy to offer a modern replacement for passwords that meets our security requirements: passkeys.

What are passkeys?

Passkeys are a secure and convenient alternative to passwords. They are a form of user authentication that doesn't require the user to remember yet another password, and are guaranteed to be unique for each account and site you visit. Each passkey is tied to the specific app or website it was created for, and can’t be phished by a lookalike domain name or fake login page design. Passkeys are synchronized across devices using services you already use and trust, like iCloud Keychain from Apple, Google Password Manager, and 1Password. For a detailed understanding of passkeys, we recommend the overview on passkeys from Apple.

How do passkeys work with Tailscale?

To add a user with a passkey to your tailnet, if you’re an admin, you can generate an invite from the Users page of the admin console. Click Invite users, then Invite via link..., and select the role you’d like the invited user to have. Then, share the unique invite URL with that user. When the invited user opens the link, they'll be able to create a unique username and join your tailnet.

A tailnet admin creates a unique invitation, tied to a specific role, which can be shared with the user you want to invite.
Users can accept an invite to a tailnet using any identity provider they choose, including passkeys, as shown here.

When a user joins a tailnet with a passkey, a public/private key pair unique to Tailscale is generated. The public key is sent to Tailscale, and the private key is stored on your device. The passkey identity is unique across all of Tailscale — the new user is a member of the inviting tailnet, but they don’t belong to the domain, and receive their own personal tailnet, as well. They can use this new passkey identity to join other tailnets if invited.

Only admins who can invite users can invite users with passkeys.

Why use a passkey?

Passkeys allow you to go passwordless — rather than a password that can still be phished — you get strong credential that syncs securely across your devices, using your chosen password/passkey manager.

If you’re not ready to make the move to passkeys, here’s another reason you might want to use them — to create a backup user for your tailnet. Invite yourself as an admin of your tailnet, with a passkey user on a yubikey. Just as you might register multiple hardware second factors for an account, create a backup Tailscale user in case you get locked out of your primary account. At this time, you cannot add a passkey to an existing login, so this method of creating backup access to your tailnet does require an additional user.

Available today

Passkeys are available in beta for all tailnets. You can use passkeys with Apple’s macOS and iOS, Google Chrome and Android, as well as 1Password, Yubikey, and any other passkey provider. To get started, see the documentation Setting up passkeys to work with Tailscale.

Share

Authors

Ben Lee-CohenBen Lee-Cohen
Jeff SpencerJeff Spencer
Loading...

Try Tailscale for free

Schedule a demo
Contact sales
cta phone
mercury
instacrt
Retool
duolingo
Hugging Face