tlsv1_cred.h revision d7ff03d48f825360eec2a371e3361306f2fd721b
1/*
2 * TLSv1 credentials
3 * Copyright (c) 2006-2007, Jouni Malinen <j@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
12struct 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
29
30struct tlsv1_credentials * tlsv1_cred_alloc(void);
31void tlsv1_cred_free(struct tlsv1_credentials *cred);
32int tlsv1_set_ca_cert(struct tlsv1_credentials *cred, const char *cert,
33		      const u8 *cert_blob, size_t cert_blob_len,
34		      const char *path);
35int tlsv1_set_cert(struct tlsv1_credentials *cred, const char *cert,
36		   const u8 *cert_blob, size_t cert_blob_len);
37int tlsv1_set_private_key(struct tlsv1_credentials *cred,
38			  const char *private_key,
39			  const char *private_key_passwd,
40			  const u8 *private_key_blob,
41			  size_t private_key_blob_len);
42int tlsv1_set_dhparams(struct tlsv1_credentials *cred, const char *dh_file,
43		       const u8 *dh_blob, size_t dh_blob_len);
44
45#endif /* TLSV1_CRED_H */
46