15 #include "tlsgnutlsserveranon.h"
32 gnutls_anon_free_server_credentials( m_anoncred );
33 gnutls_dh_params_deinit( m_dhParams );
42 void GnuTLSServerAnon::init()
44 const int protocolPriority[] = { GNUTLS_TLS1, 0 };
45 const int kxPriority[] = { GNUTLS_KX_ANON_DH, 0 };
46 const int cipherPriority[] = { GNUTLS_CIPHER_AES_256_CBC, GNUTLS_CIPHER_AES_128_CBC,
47 GNUTLS_CIPHER_3DES_CBC, GNUTLS_CIPHER_ARCFOUR, 0 };
48 const int compPriority[] = { GNUTLS_COMP_ZLIB, GNUTLS_COMP_NULL, 0 };
49 const int macPriority[] = { GNUTLS_MAC_SHA, GNUTLS_MAC_MD5, 0 };
51 if( gnutls_global_init() != 0 )
54 if( gnutls_anon_allocate_server_credentials( &m_anoncred ) < 0 )
58 gnutls_anon_set_server_dh_params( m_anoncred, m_dhParams );
60 if( gnutls_init( m_session, GNUTLS_SERVER ) != 0 )
63 gnutls_protocol_set_priority( *m_session, protocolPriority );
64 gnutls_cipher_set_priority( *m_session, cipherPriority );
65 gnutls_compression_set_priority( *m_session, compPriority );
66 gnutls_kx_set_priority( *m_session, kxPriority );
67 gnutls_mac_set_priority( *m_session, macPriority );
68 gnutls_credentials_set( *m_session, GNUTLS_CRD_ANON, m_anoncred );
70 gnutls_dh_set_prime_bits( *m_session, m_dhBits );
72 gnutls_transport_set_ptr( *m_session, (gnutls_transport_ptr_t)
this );
73 gnutls_transport_set_push_function( *m_session, pushFunc );
74 gnutls_transport_set_pull_function( *m_session, pullFunc );
77 void GnuTLSServerAnon::generateDH()
79 gnutls_dh_params_init( &m_dhParams );
80 gnutls_dh_params_generate2( m_dhParams, m_dhBits );
83 void GnuTLSServerAnon::getCertInfo()
88 info = gnutls_compression_get_name( gnutls_compression_get( *m_session ) );
92 info = gnutls_mac_get_name( gnutls_mac_get( *m_session ) );
94 m_certInfo.
mac = info;
96 info = gnutls_cipher_get_name( gnutls_cipher_get( *m_session ) );
100 info = gnutls_protocol_get_name( gnutls_protocol_get_version( *m_session ) );
109 #endif // HAVE_GNUTLS