Home | History | Annotate | Download | only in tls
      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