Home | History | Annotate | Download | only in tls
      1 /*
      2  * TLSv1 server (RFC 2246)
      3  * Copyright (c) 2006-2007, Jouni Malinen <j (at) w1.fi>
      4  *
      5  * This program is free software; you can redistribute it and/or modify
      6  * it under the terms of the GNU General Public License version 2 as
      7  * published by the Free Software Foundation.
      8  *
      9  * Alternatively, this software may be distributed under the terms of BSD
     10  * license.
     11  *
     12  * See README and COPYING for more details.
     13  */
     14 
     15 #ifndef TLSV1_SERVER_H
     16 #define TLSV1_SERVER_H
     17 
     18 #include "tlsv1_cred.h"
     19 
     20 struct tlsv1_server;
     21 
     22 int tlsv1_server_global_init(void);
     23 void tlsv1_server_global_deinit(void);
     24 struct tlsv1_server * tlsv1_server_init(struct tlsv1_credentials *cred);
     25 void tlsv1_server_deinit(struct tlsv1_server *conn);
     26 int tlsv1_server_established(struct tlsv1_server *conn);
     27 int tlsv1_server_prf(struct tlsv1_server *conn, const char *label,
     28 		     int server_random_first, u8 *out, size_t out_len);
     29 u8 * tlsv1_server_handshake(struct tlsv1_server *conn,
     30 			    const u8 *in_data, size_t in_len, size_t *out_len);
     31 int tlsv1_server_encrypt(struct tlsv1_server *conn,
     32 			 const u8 *in_data, size_t in_len,
     33 			 u8 *out_data, size_t out_len);
     34 int tlsv1_server_decrypt(struct tlsv1_server *conn,
     35 			 const u8 *in_data, size_t in_len,
     36 			 u8 *out_data, size_t out_len);
     37 int tlsv1_server_get_cipher(struct tlsv1_server *conn, char *buf,
     38 			    size_t buflen);
     39 int tlsv1_server_shutdown(struct tlsv1_server *conn);
     40 int tlsv1_server_resumed(struct tlsv1_server *conn);
     41 int tlsv1_server_get_keys(struct tlsv1_server *conn, struct tls_keys *keys);
     42 int tlsv1_server_get_keyblock_size(struct tlsv1_server *conn);
     43 int tlsv1_server_set_cipher_list(struct tlsv1_server *conn, u8 *ciphers);
     44 int tlsv1_server_set_verify(struct tlsv1_server *conn, int verify_peer);
     45 
     46 typedef int (*tlsv1_server_session_ticket_cb)
     47 (void *ctx, const u8 *ticket, size_t len, const u8 *client_random,
     48  const u8 *server_random, u8 *master_secret);
     49 
     50 void tlsv1_server_set_session_ticket_cb(struct tlsv1_server *conn,
     51 					tlsv1_server_session_ticket_cb cb,
     52 					void *ctx);
     53 
     54 #endif /* TLSV1_SERVER_H */
     55