diff options
author | madmaxoft <github@xoft.cz> | 2014-04-27 22:27:53 +0200 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-04-27 22:27:53 +0200 |
commit | 0bdc49221b325feb3a09988737559361fe916be2 (patch) | |
tree | 4d534326cc07ce4898bb74cfe7a3275c7bdc931e /src/PolarSSL++/BufferedSslContext.cpp | |
parent | cSocket creates the socket in Connect if no socket is present yet. (diff) | |
download | cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar.gz cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar.bz2 cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar.lz cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar.xz cuberite-0bdc49221b325feb3a09988737559361fe916be2.tar.zst cuberite-0bdc49221b325feb3a09988737559361fe916be2.zip |
Diffstat (limited to 'src/PolarSSL++/BufferedSslContext.cpp')
-rw-r--r-- | src/PolarSSL++/BufferedSslContext.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/src/PolarSSL++/BufferedSslContext.cpp b/src/PolarSSL++/BufferedSslContext.cpp new file mode 100644 index 000000000..885b30c68 --- /dev/null +++ b/src/PolarSSL++/BufferedSslContext.cpp @@ -0,0 +1,62 @@ + +// BufferedSslContext.cpp + +// Implements the cBufferedSslContext class representing a SSL context with the SSL peer data backed by a cByteBuffer + +#include "Globals.h" +#include "BufferedSslContext.h" + + + + + +cBufferedSslContext::cBufferedSslContext(size_t a_BufferSize): + m_OutgoingData(a_BufferSize), + m_IncomingData(a_BufferSize) +{ +} + + + + + +int cBufferedSslContext::ReceiveEncrypted(unsigned char * a_Buffer, size_t a_NumBytes) +{ + // Called when PolarSSL wants to read encrypted data from the SSL peer + // Read the data from the buffer inside this object, where the owner has stored them using WriteIncoming(): + size_t NumBytes = std::min(a_NumBytes, m_IncomingData.GetReadableSpace()); + if (NumBytes == 0) + { + return POLARSSL_ERR_NET_WANT_READ; + } + if (!m_IncomingData.ReadBuf(a_Buffer, NumBytes)) + { + m_IncomingData.ResetRead(); + return POLARSSL_ERR_NET_RECV_FAILED; + } + m_IncomingData.CommitRead(); + return (int)NumBytes; +} + + + + + +int cBufferedSslContext::SendEncrypted(const unsigned char * a_Buffer, size_t a_NumBytes) +{ + // Called when PolarSSL wants to write encrypted data to the SSL peer + // Write the data into the buffer inside this object, where the owner can later read them using ReadOutgoing(): + if (!m_OutgoingData.CanWriteBytes(a_NumBytes)) + { + return POLARSSL_ERR_NET_WANT_WRITE; + } + if (!m_OutgoingData.Write((const char *)a_Buffer, a_NumBytes)) + { + return POLARSSL_ERR_NET_SEND_FAILED; + } + return (int)a_NumBytes; +} + + + + |