1 /* 2 * TLSv1 credentials 3 * Copyright (c) 2006-2007, Jouni Malinen <j (at) w1.fi> 4 * 5 * This software may be distributed under the terms of the BSD license. 6 * See README for more details. 7 */ 8 9 #ifndef TLSV1_CRED_H 10 #define TLSV1_CRED_H 11 12 struct tlsv1_credentials { 13 struct x509_certificate *trusted_certs; 14 struct x509_certificate *cert; 15 struct crypto_private_key *key; 16 17 unsigned int cert_probe:1; 18 unsigned int ca_cert_verify:1; 19 unsigned int server_cert_only:1; 20 u8 srv_cert_hash[32]; 21 22 /* Diffie-Hellman parameters */ 23 u8 *dh_p; /* prime */ 24 size_t dh_p_len; 25 u8 *dh_g; /* generator */ 26 size_t dh_g_len; 27 28 char *ocsp_stapling_response; 29 char *ocsp_stapling_response_multi; 30 }; 31 32 33 struct tlsv1_credentials * tlsv1_cred_alloc(void); 34 void tlsv1_cred_free(struct tlsv1_credentials *cred); 35 int tlsv1_set_ca_cert(struct tlsv1_credentials *cred, const char *cert, 36 const u8 *cert_blob, size_t cert_blob_len, 37 const char *path); 38 int tlsv1_set_cert(struct tlsv1_credentials *cred, const char *cert, 39 const u8 *cert_blob, size_t cert_blob_len); 40 int tlsv1_set_private_key(struct tlsv1_credentials *cred, 41 const char *private_key, 42 const char *private_key_passwd, 43 const u8 *private_key_blob, 44 size_t private_key_blob_len); 45 int tlsv1_set_dhparams(struct tlsv1_credentials *cred, const char *dh_file, 46 const u8 *dh_blob, size_t dh_blob_len); 47 48 #endif /* TLSV1_CRED_H */ 49