15 #include "tlsgnutlsbase.h"
30 :
TLSBase( th, server ), m_session( new gnutls_session_t ), m_buf( 0 ), m_bufsize( 17000 )
32 m_buf = (
char*)calloc( m_bufsize + 1,
sizeof(
char ) );
56 std::string::size_type sum = 0;
59 ret = gnutls_record_send( *m_session, data.c_str() + sum, data.length() - sum );
62 while( ( ret == GNUTLS_E_AGAIN ) || ( ret == GNUTLS_E_INTERRUPTED ) || sum < data.length() );
73 return static_cast<int>( data.length() );
80 ret =
static_cast<int>( gnutls_record_recv( *m_session, m_buf, m_bufsize ) );
82 if( ret > 0 && m_handler )
100 gnutls_bye( *m_session, GNUTLS_SHUT_RDWR );
101 gnutls_db_remove_session( *m_session );
102 gnutls_credentials_clear( *m_session );
104 gnutls_deinit( *m_session );
110 m_session =
new gnutls_session_t;
121 int ret = gnutls_handshake( *m_session );
122 if( ret < 0 && gnutls_error_is_fatal( ret ) )
124 gnutls_perror( ret );
125 gnutls_db_remove_session( *m_session );
126 gnutls_deinit( *m_session );
132 else if( ret == GNUTLS_E_AGAIN )
145 ssize_t GnuTLSBase::pullFunc(
void* data,
size_t len )
147 ssize_t cpy = ( len > m_recvBuffer.length() ) ? ( m_recvBuffer.length() ) : ( len );
150 memcpy( data, (
const void*)m_recvBuffer.c_str(), cpy );
151 m_recvBuffer.erase( 0, cpy );
157 return GNUTLS_E_AGAIN;
161 ssize_t GnuTLSBase::pullFunc( gnutls_transport_ptr_t ptr,
void* data,
size_t len )
163 return static_cast<GnuTLSBase*
>( ptr )->pullFunc( data, len );
166 ssize_t GnuTLSBase::pushFunc(
const void* data,
size_t len )
174 ssize_t GnuTLSBase::pushFunc( gnutls_transport_ptr_t ptr,
const void* data,
size_t len )
176 return static_cast<GnuTLSBase*
>( ptr )->pushFunc( data, len );
181 #endif // HAVE_GNUTLS
GnuTLSBase(TLSHandler *th, const std::string &server=EmptyString)
virtual void handleEncryptedData(const TLSBase *base, const std::string &data)=0
virtual int decrypt(const std::string &data)
An abstract base class for TLS implementations.
virtual void handleDecryptedData(const TLSBase *base, const std::string &data)=0
virtual bool encrypt(const std::string &data)
An interface that allows for interacting with TLS implementations derived from TLSBase.
virtual void handleHandshakeResult(const TLSBase *base, bool success, CertInfo &certinfo)=0