|  |  |  | GnuTLS API Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#define GNUTLS_TPM_KEY_SIGNING #define GNUTLS_TPM_KEY_USER #define GNUTLS_TPM_REGISTER_KEY int gnutls_tpm_get_registered (gnutls_tpm_key_list_t *list); void gnutls_tpm_key_list_deinit (gnutls_tpm_key_list_t list); int gnutls_tpm_key_list_get_url (gnutls_tpm_key_list_t list,unsigned int idx,char **url,unsigned int flags); typedef gnutls_tpm_key_list_t; int gnutls_tpm_privkey_delete (const char *url,const char *srk_password); int gnutls_tpm_privkey_generate (gnutls_pk_algorithm_t pk,unsigned int bits,const char *srk_password,const char *key_password,gnutls_tpmkey_fmt_t format,gnutls_x509_crt_fmt_t pub_format,gnutls_datum_t *privkey,gnutls_datum_t *pubkey,unsigned int flags); enum gnutls_tpmkey_fmt_t; struct tpm_key_list_st;
int                 gnutls_tpm_get_registered           (gnutls_tpm_key_list_t *list);
This function will get a list of stored keys in the TPM. The uuid of those keys
| 
 | a list to store the keys | 
| Returns : | On success, GNUTLS_E_SUCCESS(0) is returned, otherwise a
negative error value. | 
Since 3.1.0
void                gnutls_tpm_key_list_deinit          (gnutls_tpm_key_list_t list);
This function will deinitialize the list of stored keys in the TPM.
| 
 | a list of the keys | 
Since 3.1.0
int gnutls_tpm_key_list_get_url (gnutls_tpm_key_list_t list,unsigned int idx,char **url,unsigned int flags);
This function will return for each given index a URL of
the corresponding key.
If the provided index is out of bounds then GNUTLS_E_REQUESTED_DATA_NOT_AVAILABLE
is returned.
| 
 | a list of the keys | 
| 
 | The index of the key (starting from zero) | 
| 
 | The URL to be returned | 
| 
 | should be zero | 
| Returns : | On success, GNUTLS_E_SUCCESS(0) is returned, otherwise a
negative error value. | 
Since 3.1.0
int gnutls_tpm_privkey_delete (const char *url,const char *srk_password);
This function will unregister the private key from the TPM chip.
| 
 | the URL describing the key | 
| 
 | a password for the SRK key | 
| Returns : | On success, GNUTLS_E_SUCCESS(0) is returned, otherwise a
negative error value. | 
Since 3.1.0
int gnutls_tpm_privkey_generate (gnutls_pk_algorithm_t pk,unsigned int bits,const char *srk_password,const char *key_password,gnutls_tpmkey_fmt_t format,gnutls_x509_crt_fmt_t pub_format,gnutls_datum_t *privkey,gnutls_datum_t *pubkey,unsigned int flags);
This function will generate a private key in the TPM
chip. The private key will be generated within the chip
and will be exported in a wrapped with TPM's master key
form. Furthermore the wrapped key can be protected with
the provided password.
Note that bits in TPM is quantized value. If the input value is not one of the allowed values, then it will be quantized to one of 512, 1024, 2048, 4096, 8192 and 16384.
Allowed flags are:
GNUTLS_TPM_KEY_SIGNING: Generate a signing key instead of a legacy,
GNUTLS_TPM_REGISTER_KEY: Register the generate key in TPM. In that
case privkey would contain a URL with the UUID.
| 
 | the public key algorithm | 
| 
 | the security bits | 
| 
 | a password to protect the exported key (optional) | 
| 
 | the password for the TPM (optional) | 
| 
 | the format of the private key | 
| 
 | the format of the public key | 
| 
 | the generated key | 
| 
 | the corresponding public key (may be null) | 
| 
 | should be a list of GNUTLS_TPM_* flags | 
| Returns : | On success, GNUTLS_E_SUCCESS(0) is returned, otherwise a
negative error value. | 
Since 3.1.0
typedef enum {
    GNUTLS_TPMKEY_FMT_RAW = 0,
    GNUTLS_TPMKEY_FMT_DER = GNUTLS_TPMKEY_FMT_RAW,
    GNUTLS_TPMKEY_FMT_CTK_PEM = 1
} gnutls_tpmkey_fmt_t;
Enumeration of different certificate encoding formats.