2022-08-28 19:02:06 +00:00
|
|
|
/***
|
|
|
|
Copyright (C) 2022 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
|
|
|
|
File: TLSProtocolSend.cpp
|
|
|
|
Date: 2022-8-24
|
|
|
|
Author: Reece
|
|
|
|
***/
|
|
|
|
#include "TLS.hpp"
|
|
|
|
#include "TLSContext.hpp"
|
|
|
|
|
|
|
|
namespace Aurora::IO::TLS
|
|
|
|
{
|
|
|
|
TLSProtocolSend::TLSProtocolSend(TLSContext *pParent) :
|
|
|
|
pParent_(pParent)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool TLSProtocolSend::OnDataAvailable(const AuSPtr<Memory::ByteBuffer> &pReadInByteBuffer,
|
|
|
|
const AuSPtr<Memory::ByteBuffer> &pWriteOutByteBuffer)
|
|
|
|
{
|
|
|
|
if (!this->pParent_->bIsAlive)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pReadInByteBuffer->writePtr == pReadInByteBuffer->readPtr)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (pReadInByteBuffer->writePtr != pReadInByteBuffer->readPtr)
|
|
|
|
{
|
2022-08-30 23:06:50 +00:00
|
|
|
auto pDest = pReadInByteBuffer->GetNextLinearRead();
|
|
|
|
const AuUInt8 *pBase { pDest.ToPointer() };
|
|
|
|
AuUInt uCount { pDest.length };
|
2022-08-28 19:02:06 +00:00
|
|
|
|
|
|
|
if (!uCount)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
int iRet = ::mbedtls_ssl_write(&this->pParent_->ssl,
|
|
|
|
pBase,
|
|
|
|
uCount);
|
|
|
|
|
|
|
|
if ((iRet == MBEDTLS_ERR_SSL_WANT_READ) ||
|
|
|
|
(iRet == MBEDTLS_ERR_SSL_WANT_WRITE))
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (iRet < 0)
|
|
|
|
{
|
|
|
|
this->pParent_->iFatalError = iRet;
|
|
|
|
SysPushErrorNet("{}", iRet);
|
|
|
|
this->pParent_->OnFatal();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
pReadInByteBuffer->readPtr += iRet;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|