Using a TPM for SSH keys on OpenSUSE Tumbleweed

Using a TPM for SSH keys on OpenSUSE Tumbleweed

In some environments it is required to store ssh private keys in a way where they can not be extracted from the machine. Trusted Platform Modules (TPM) are an excellent way to achieve this. While other guides exist online for how to configure this for other distributions, this will focus on OpenSUSE Tumbleweed.

Install Packages

The following is required to be installed.

zypper install tpm2-pkcs11 tpm2.0-tools tpm2-0-tss libtpm2_pkcs11-0
  • tpm2-pkcs11 - tools to configure keys in a tpm via PKCS11
  • tpm2.0-tools - tools for TPM introspection
  • tpm2-0-tss - udev rules and tss group
  • libtpm2_pkcs11-0 - library for ssh to access TPM via PKCS11

Check the TPM exists

You can check the TPM exists and is working with:

ls -l /dev/tpm*
# crw-rw---- 1 tss root  10,   224 Apr 19 18:39 /dev/tpm0

To check the supported algorithms on the TPM:

tpm2_getcap algorithms

If this command errors, your TPM may be misconfigured or you may not have access to the TPM.

HINT: You can add a TPM to a KVM virtual machine with virt-install with the line:

--tpm backend.type=emulator,backend.version=2.0,model=tpm-tis

From virt-manager you can add the TPM via "Add Hardware", "TPM".

Editing the virtual machine xml directly a TPM can be defined with:

<domain type='kvm'>
  <devices>
    <tpm model='tpm-tis'>
      <backend type='emulator' version='2.0'/>
    </tpm>
  </devices>
</domain>

Allow User Access

Add your user to the tss group

usermod -a -G tss username

Execute FAPI Provisioning

The tpm2 library comes with a feature api (FAPI), which annoyingly needs provisioning before we can proceed. If you skip this provisioning step, you will be annoyed by a pointless warning message every time you use your ssh key.

If you attempt the provisioning later, you will BREAK YOUR KEYS.

Edit /etc/tpm2-tss/fapi-config.json and ensure this line is present:

     "ek_cert_less": "yes",

now run:

tss2_provision

HINT: If you have errors you can get more output with:

TSS2_LOG=fapi+debug tss2_provision

If you get an error about "An SRK already exists", you can clear it with:

tpm2_evictcontrol -C o -c 0x81000001

Configure the SSH key

NOTE Be sure to perform these steps as your user - not as root!

Initialise the tpm PKCS11 store - note the id in the output.

tpm2_ptool init
# action: Created
# id: 1

Using the id from the above output, you can use that to create a new token. Note here that the userpin is the pin for using the ssh key. The sopin is the recovery password incase you lose the pin and need to reset it.

tpm2_ptool addtoken --pid=1 --label=ssh --userpin="" --sopin=""
tpm2_ptool addkey --label=ssh --userpin="" --algorithm=ecc256

If you want to use a different key algorithm, other choices are rsa2048, rsa3072, rsa4096, ecc256, ecc384, ecc521.

Now you can view the public key with:

ssh-keygen -D /usr/lib64/pkcs11/libtpm2_pkcs11.so.0

It's a good idea to store this into a file for later:

ssh-keygen -D /usr/lib64/pkcs11/libtpm2_pkcs11.so.0 | tee ~/.ssh/id_ecdsa_tpm.pub

Using the SSH Key

You can modify your ssh configuration to always use the key. You will be prompted for the userpin to access the ssh key as required.

# ~/.ssh/config

PKCS11Provider /usr/lib64/pkcs11/libtpm2_pkcs11.so.0
PasswordAuthentication no