1 /* 2 * ustream-ssl - library for SSL over ustream 3 * 4 * Copyright (C) 2012 Felix Fietkau <nbd@openwrt.org> 5 * 6 * Permission to use, copy, modify, and/or distribute this software for any 7 * purpose with or without fee is hereby granted, provided that the above 8 * copyright notice and this permission notice appear in all copies. 9 * 10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 17 */ 18 19 #ifndef __USTREAM_POLARSSL_H 20 #define __USTREAM_POLARSSL_H 21 22 #include <mbedtls/net_sockets.h> 23 #include <mbedtls/ssl.h> 24 #include <mbedtls/certs.h> 25 #include <mbedtls/x509.h> 26 #include <mbedtls/rsa.h> 27 #include <mbedtls/error.h> 28 #include <mbedtls/version.h> 29 #include <mbedtls/entropy.h> 30 31 #if defined(MBEDTLS_SSL_CACHE_C) 32 #include <mbedtls/ssl_cache.h> 33 #endif 34 35 struct ustream_ssl_ctx { 36 mbedtls_ssl_config conf; 37 mbedtls_pk_context key; 38 mbedtls_x509_crt ca_cert; 39 mbedtls_x509_crt cert; 40 #if defined(MBEDTLS_SSL_CACHE_C) 41 mbedtls_ssl_cache_context cache; 42 #endif 43 bool server; 44 int *ciphersuites; 45 }; 46 47 static inline char *__ustream_ssl_strerror(int error, char *buffer, int len) 48 { 49 mbedtls_strerror(error, buffer, len); 50 return buffer; 51 } 52 53 static inline void __ustream_ssl_set_server_name(struct ustream_ssl *us) 54 { 55 mbedtls_ssl_set_hostname(us->ssl, us->server_name); 56 } 57 58 static inline void __ustream_ssl_update_peer_cn(struct ustream_ssl *us) 59 { 60 mbedtls_ssl_set_hostname(us->ssl, us->peer_cn); 61 } 62 63 void __ustream_ssl_session_free(void *ssl); 64 void *__ustream_ssl_session_new(struct ustream_ssl_ctx *ctx); 65 66 #endif 67
This page was automatically generated by LXR 0.3.1. • OpenWrt