Skip to content

Files

Latest commit

 

History

History
104 lines (82 loc) · 4.46 KB

authentication.md

File metadata and controls

104 lines (82 loc) · 4.46 KB

Authentication in hoopsnake

There are two main ways authentication happens: The authentication that hoopsnake does to the tailnet, and the authentication that happens between the hoopsnake SSH server and an SSH client.

Tailnet authentication

In order for hoopsnake to get a "device" registered the tailnet, it needs a pre-authenticated key (an "authkey" in tailscale docs). These can come in several ways, and of course there is a recommendation to you for the best method:

  • Specify an authkey on the environment directly
  • Specify an API key, and hoopsnake mints an ephemeral authkey from that
  • Specify an oauth client ID and secret, and hoopsnake mints an ephemeral authkey from that.

Unfortunately, if you're using tailscale, the last method (the oauth client keypair) is the best and most reasonable way to keep your devices booting, and stay securely out of other devices' ways.

Auth and "all-powerful" API access tokens

You can make one of these in the Keys section in your tailnet console (or with the headscale CLI).

In tailnet at least, these have a 90-day lifetime limit. I don't recommend them specifically due to this limit: If you reboot your machine on day 91, you are locked out and life sucks until you have gotten the machine back online & minted another key, then gotten that put on the machine. And in 91 days, that same issue repeats. It is not great.

To use auth or api keys:

  1. Generate one on the Keys page
  2. If you generated an auth key, set TS_AUTHKEY to that value
  3. If you generated an API key, set TS_API_KEY to that value
  4. Remember - you only need either an auth or an api key.
  5. Run headscale ...
  6. Remember to rotate the key every 90 days!

Oauth keypairs on tailscale (recommended!)

So instead, tailscale lets you make scoped oauth access keys, which not only have way less power than API keys (but plenty of power in the area we need!), and have an unrestricted lifetime.

Unless you revoke the oauth token, your machine will remain able to boot.

To use oauth keypairs,

  1. Set up an ACL tag on the ACL page, under the tagOwners key.
  2. Ensure whatever devices you use to access your hoopsnake SSH service have access to devices tagged that, port 22. That's under the acls key.
  3. Generate one on the oauth clients page and bind it to that tag.
  4. Write the client ID to a file and pass its pathname as -clientIdFile
  5. Write the client secret to another file and pass its pathname as -clientSecretFile.
  6. (You can also set TS_API_CLIENT_ID and TS_API_CLIENT_SECRET env variables if those are more convenient. But you can't mix and match the environment variable / file strategy.)
  7. Run hoopsnake ... and it should be a proper tailscale oauth client.

other considerations: Cleaning out old device entries

hoopsnake will mint auth tokens that generate "ephemeral" devices. That means that once you're finished booting, the device goes away and gets cleaned up by tailscale. The next time you boot (hopefully not within a half hour to a few hours), the "your-device-name" name will be free, and you can still reach it under that name.

...that is, if you do only reboot only when the tailscale ephemeral cleanout job has had a chance to run. headscale has an option -deleteExisting (with -maxNodeAge) that will search for nodes that have the same name as the requested name, and if they've been offline for at least maxNodeAge, will delete them before registering itself.

If you use the oauth client authentication method, you can use -deleteExisting, and I highly recommend it.

SSH authentication

hoopsnake supports only SSH public key authentication. Use the flag -authorizedKeys to specify an authorized_keys file in the typical SSH format. You can even generate one from github if you like, with the following commandline: curl https://api.github.com/users/$(whoami)/keys | jq -r '.[].key' (that is, if your login name is your github username; substitute that $(whoami) for your github username if not).

The SSH server also needs a private key to finish the handshake (and authentication to the client). You can generate one with the commandline ssh-keygen -t ssh-keygen -t ed25519 -f hoopsnake and tell hoopsnake to use that file with the -hostKey flag.