gnutls_certificate_set_key(3) API function


#include <gnutls/abstract.h>

int gnutls_certificate_set_key(gnutls_certificate_credentials_t res, const char ** names, int names_size, gnutls_pcert_st * pcert_list, int pcert_list_size, gnutls_privkey_t key);


gnutls_certificate_credentials_t res
is a gnutls_certificate_credentials_t type.
const char ** names
is an array of DNS name of the certificate (NULL if none)
int names_size
holds the size of the names list
gnutls_pcert_st * pcert_list
contains a certificate list (path) for the specified private key
int pcert_list_size
holds the size of the certificate list
gnutls_privkey_t key
is a gnutls_privkey_t key


This function sets a certificate/private key pair in the gnutls_certificate_credentials_t type. This function may be called more than once, in case multiple keys/certificates exist for the server. For clients that wants to send more than its own end entity certificate (e.g., also an intermediate CA cert) then put the certificate chain in pcert_list .

Note that the key and the elements of pcert_list will become part of the credentials structure and must not be deallocated. They will be automatically deallocated when the res type is deinitialized.

If that function fails to load the res structure is at an undefined state, it must not be reused to load other keys or certificates.


GNUTLS_E_SUCCESS (0) on success, or a negative error code.




Report bugs to <[email protected]>.
Home page:


Copyright © 2001-2016 Free Software Foundation, Inc., and others.
Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved.