18d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt/* 21f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt * TLS v1.0/v1.1/v1.2 client (RFC 2246, RFC 4346, RFC 5246) 3c55524ad84d13014e8019491c2b17e5dcf13545aDmitry Shmidt * Copyright (c) 2006-2011, Jouni Malinen <j@w1.fi> 48d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt * 5c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * This software may be distributed under the terms of the BSD license. 6c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * See README for more details. 78d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt */ 88d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 98d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#ifndef TLSV1_CLIENT_H 108d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#define TLSV1_CLIENT_H 118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "tlsv1_cred.h" 138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct tlsv1_client; 158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 168d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_global_init(void); 178d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtvoid tlsv1_client_global_deinit(void); 188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct tlsv1_client * tlsv1_client_init(void); 198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtvoid tlsv1_client_deinit(struct tlsv1_client *conn); 208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_established(struct tlsv1_client *conn); 218d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_prf(struct tlsv1_client *conn, const char *label, 228d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int server_random_first, u8 *out, size_t out_len); 238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtu8 * tlsv1_client_handshake(struct tlsv1_client *conn, 248d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *in_data, size_t in_len, 258d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t *out_len, u8 **appl_data, 261f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt size_t *appl_data_len, int *need_more_data); 278d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_encrypt(struct tlsv1_client *conn, 288d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *in_data, size_t in_len, 298d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u8 *out_data, size_t out_len); 301f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtstruct wpabuf * tlsv1_client_decrypt(struct tlsv1_client *conn, 311f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const u8 *in_data, size_t in_len, 321f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt int *need_more_data); 338d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_get_cipher(struct tlsv1_client *conn, char *buf, 348d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t buflen); 358d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_shutdown(struct tlsv1_client *conn); 368d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_resumed(struct tlsv1_client *conn); 378d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_hello_ext(struct tlsv1_client *conn, int ext_type, 388d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *data, size_t data_len); 398d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_get_keys(struct tlsv1_client *conn, struct tls_keys *keys); 408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_get_keyblock_size(struct tlsv1_client *conn); 418d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_set_cipher_list(struct tlsv1_client *conn, u8 *ciphers); 428d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint tlsv1_client_set_cred(struct tlsv1_client *conn, 438d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct tlsv1_credentials *cred); 44c55524ad84d13014e8019491c2b17e5dcf13545aDmitry Shmidtvoid tlsv1_client_set_time_checks(struct tlsv1_client *conn, int enabled); 458d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidttypedef int (*tlsv1_client_session_ticket_cb) 478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt(void *ctx, const u8 *ticket, size_t len, const u8 *client_random, 488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *server_random, u8 *master_secret); 498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtvoid tlsv1_client_set_session_ticket_cb(struct tlsv1_client *conn, 518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt tlsv1_client_session_ticket_cb cb, 528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt void *ctx); 538d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 548d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#endif /* TLSV1_CLIENT_H */ 55