Skip to content

Overview

NSA Personnel edited this page Dec 2, 2019 · 2 revisions

This page is designed to give insight into the intended use of Kmyth along with the processes involved. The processes described on this page should generalize to implementations using TPM 1.2. Note that we denote the kmyth tool with all lower case letters, while Kmyth refers to the project.

For more details on TPM-specific implementations, see:

TPM 1.2:   kmyth-seal    kmyth-unseal    kmyth-getkey

Kmyth Components

Kmyth is designed to do the heavy lifting for the user, in that it abstracts details of TPM interactions as much as possible.

kmyth-seal

Although kmyth-seal can be used to ensure the confidentiality of any type of data, for the sake of kmyth-getkey, we assume the data to be protected is the client authentication private key (CAPK). Kmyth-seal involves more than just binding data to the TPM. It includes the entire process from storage key creation through saving the encrypted CAPK. The individual steps are:

  1. Create a storage key.
  2. Create the client wrapping key (CWK).
  3. Encrypt the CAPK. The default encryption algorithm is AES/GCM/NoPadding/256.
  4. Seal the client wrapping key to the TPM.
  5. Store a .ski file containing the sealed CWK and SK, and the encrypted CAPK, along with necessary metadata required to reconstruct the original CAPK.

A good question one might ask at this point is "Why use a separate wrapping key instead of just sealing the CAPK directly?" The reason for this is because the TPM can only seal small data blobs, and the file containing the private key will possibly (and likely for RSA) be too long to seal in one pass. While the file could be broken into multiple parts and each part could be sealed separately, using a wrapping key is cleaner and still provides a TPM supported key hierarchy. This is also the approach taken by tpm-tools. There are two key differences between kmyth and tpm-tools. First, kmyth allows the user to select the algorithm used to encrypt the CAPK. Second, kmyth only uses the WKS. This is because kmyth is intended to be used in a distributed system where requiring a human to input a password for each unseal is not practical.

kmyth-unseal

Kmyth-unsealing is the process of obtaining the material protected by the TPM. The individual steps are almost the reverse of kmyth-seal:

  1. Input the .ski file.
  2. Unseal the CWK.
  3. Unwrap the CAPK using the CWK.
  4. Write the CAPK to disk or to stdout.

kmyth-getkey

Kmyth is intended to be used in conjunction with a key server for operational key retrieval. This tool is designed to establish a TLS connection to retrieve a key from a key server. Kmyth assumes the key server has been established and already possesses a key we wish to acquire. Kmyth-getkey does not currently support any standard key retrieval protocols, e.g. KMIP.

  1. Use kmyth-unseal to access the CAPK. (The user does not need to run kmyth-unseal separately -- the functionality is implemented in kmyth-getkey.)
  2. Retrieve the operational key from key server.
  3. Output the operational key to stdout, preferably directed to a RAM file.

Key and Data Locations

Within the TPM: Storage Key, Storage Root Key, PCR values
Encrypted on local file system: CAPK, Storage Key, CWK, expected PCR values
Stored on remote key server: Operational Key

Once the operational key is retrieved, it can be used in one of three ways:

  1. Used within the program that retrieved the key
  2. Piped into another program on the command line
  3. Stored to a local file system
  • If stored to a local file system, it is strongly encouraged that the key be stored in a RAM file as briefly as possible.

Protecting Authentication Material of Nodes in a Distributed System

During client provisioning:

  1. Create an SK within the TPM.
  2. Create a CWK which will be used to encrypt the CAPK.
  3. Encrypt the CAPK.
  4. Use the SK to seal the CWK.
  5. Store the sealed SK and CWK, and the encrypted CAPK to file.

Upon client start-up: 6. Unseal the CWK using the SK. 7. Decrypt the CAPK using the CWK. 8. Retrieve the operational key with the CAPK via TLS.

Clone this wiki locally