Reece Wilson
67905a4192
============================================================================= Network ]==================================================================== ============================================================================= [+] Added (very) early Aurora::IO::Net implementation [+] AuNet::EHostnameType [+] AuNet::EIPProtocol [+] AuNet::ENetworkError [+] AuNet::ETransportProtocol [+] AuNet::INetInterface [+] AuNet::INetSrvDatagram [+] AuNet::INetSrvResolve [+] AuNet::INetSrvSockets [+] AuNet::INetSrvWorkers [+] AuNet::INetWorker [+] AuNet::IPAddress [+] AuNet::IResolver [+] AuNet::ISocket [+] AuNet::IResolver [+] AuNet::ISocketBase [+] AuNet::ISocketChannel [+] AuNet::ISocketDriver [+] AuNet::ISocketDriverFactory [+] AuNet::ISocketServer [+] AuNet::ISocketServerDriver [+] AuNet::NetEndpoint [+] AuNet::NetError [+] AuNet::NetHostname (+implementation) ============================================================================= Protocol ]=================================================================== ============================================================================= [+] IProtocolInterceptor [+] IProtocolInterceptorEx [+] IProtocolStack (+implementation) ============================================================================= TLS ]======================================================================== ============================================================================= [+] ITLSContext [+] TLSProtocolRecv [+] TLSProtocolSend (+implementation) ============================================================================= IO Bug Fixes ]=============================================================== ============================================================================= [*] IOProcessor::SubmitIOWorkItem should signal the CvEvent, forcing at least once future tick (wont optimize with if in tick & not yet dispatched work items) [*] Split IOPipeWork in into IOPipeProcessor header [+] IOPipeWork::GetBuffer (internal reallocation) [*] Harden against IAsyncTransactions without a loop source [*] Missing null `if (processor->listener)` in IOProcessor [*] Solved some soft-lock conditions under Linux's LoopQueue (added deferred commits) [*] Quick hack: IOProcessor::HasItems() should OR the early can-tick check function. ============================================================================= Other ]====================================================================== ============================================================================= [+] Linux: LSSignalCatcher [+] `static void AuResetMember(Aurora::Memory::ByteBuffer &ref)` for AuROXTL [*] Attempt to enforce a normalization and don't overwrite-readptr-under-istreamwriters policy in ByteBuffer_ReadWrite (circular buffers) [*] Bad ECC ctors ============================================================================= Known issues ]=============================================================== ============================================================================= > Linux net is nowhere near done > UDP socket emulation layer isn't implemented > Ciphersuite API is a stub > Private key API is a stub > ...therefore no TLS servers > Missing thread safety precautions under net > Net implementation is still beri early
191 lines
5.8 KiB
C++
191 lines
5.8 KiB
C++
/***
|
|
Copyright (C) 2022 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
File: AuNetError.cpp
|
|
Date-Initial: 2022-2-1 (rejected net, to replace knet)
|
|
Date-Revisited: 2022-8-17
|
|
Author: Reece
|
|
***/
|
|
#include "Networking.hpp"
|
|
#include "AuNetError.hpp"
|
|
|
|
namespace Aurora::IO::Net
|
|
{
|
|
void NetError_SetCurrent(NetError &error)
|
|
{
|
|
#if defined(AURORA_IS_MODERNNT_DERIVED)
|
|
NetError_SetOsError(error, ::WSAGetLastError());
|
|
#elif defined(AURORA_IS_POSIX_DERIVED)
|
|
NetError_SetOsError(error, errno);
|
|
#endif
|
|
}
|
|
|
|
void NetError_SetOsError(NetError &error, AuUInt value)
|
|
{
|
|
error.osError = value;
|
|
|
|
#if defined(AURORA_IS_MODERNNT_DERIVED)
|
|
|
|
switch (value)
|
|
{
|
|
case WSA_INVALID_HANDLE:
|
|
case WSA_INVALID_PARAMETER:
|
|
case WSAEDESTADDRREQ:
|
|
case WSAEPROTOTYPE:
|
|
case WSAEFAULT:
|
|
case WSAEINVAL:
|
|
case WSAEBADF:
|
|
case WSAENOTSOCK:
|
|
error.netError = ENetworkError::eIllegalArgument;
|
|
break;
|
|
case WSAETIMEDOUT:
|
|
error.netError = ENetworkError::eTimeout;
|
|
break;
|
|
case WSAEMSGSIZE:
|
|
case WSAENOBUFS:
|
|
error.netError = ENetworkError::eSocketBufferOverflow;
|
|
break;
|
|
case WSA_OPERATION_ABORTED:
|
|
case WSAESHUTDOWN:
|
|
case WSAENOTCONN:
|
|
case WSAEDISCON:
|
|
error.netError = ENetworkError::eSocketClosed;
|
|
break;
|
|
case WSAEACCES:
|
|
case WSAEPROTONOSUPPORT:
|
|
case WSAEPFNOSUPPORT:
|
|
case WSAEAFNOSUPPORT:
|
|
error.netError = ENetworkError::ePermissionDenied;
|
|
break;
|
|
case WSA_IO_INCOMPLETE:
|
|
case WSAEINTR:
|
|
case WSAEALREADY:
|
|
case WSAECANCELLED:
|
|
case WSAEINPROGRESS:
|
|
error.netError = ENetworkError::eAsyncError;
|
|
break;
|
|
case WSAEADDRINUSE:
|
|
error.netError = ENetworkError::eServiceTaken;
|
|
break;
|
|
case WSAEADDRNOTAVAIL:
|
|
case WSAEHOSTUNREACH:
|
|
case WSAEHOSTDOWN:
|
|
error.netError = ENetworkError::eEndpointRefused;
|
|
break;
|
|
case WSAECONNREFUSED:
|
|
error.netError = ENetworkError::eServiceRefused;
|
|
break;
|
|
case WSAECONNABORTED:
|
|
error.netError = ENetworkError::eConnectionReset;
|
|
break;
|
|
case WSAENETUNREACH:
|
|
error.netError = ENetworkError::eUnreachable;
|
|
break;
|
|
case WSAENETDOWN:
|
|
case WSAVERNOTSUPPORTED:
|
|
case WSANOTINITIALISED:
|
|
error.netError = ENetworkError::eNoNetwork;
|
|
break;
|
|
case WSA_NOT_ENOUGH_MEMORY:
|
|
case WSAEWOULDBLOCK:
|
|
error.netError = ENetworkError::eResourceConstraint;
|
|
break;
|
|
default:
|
|
error.netError = ENetworkError::eUnknown;
|
|
break;
|
|
case WSA_IO_PENDING:
|
|
error.netError = ENetworkError::eEnumInvalid;
|
|
break;
|
|
}
|
|
|
|
#elif defined(AURORA_IS_POSIX_DERIVED)
|
|
|
|
switch (value)
|
|
{
|
|
case EACCES:
|
|
case EPERM:
|
|
error.netError = ENetworkError::ePermissionDenied;
|
|
break;
|
|
case EAFNOSUPPORT:
|
|
case EPROTONOSUPPORT:
|
|
case EPROTOTYPE:
|
|
error.netError = ENetworkError::eBadAddress;
|
|
break;
|
|
case EMFILE:
|
|
case ENFILE:
|
|
case ENOBUFS:
|
|
error.netError = ENetworkError::eResourceConstraint;
|
|
break;
|
|
case ECONNRESET:
|
|
error.netError = ENetworkError::eConnectionReset;
|
|
break;
|
|
case ESHUTDOWN:
|
|
case ENOTCONN:
|
|
error.netError = ENetworkError::eSocketClosed;
|
|
break;
|
|
case ENOTSOCK:
|
|
case EFAULT:
|
|
case EINVAL:
|
|
case EBADF:
|
|
error.netError = ENetworkError::eIllegalArgument;
|
|
break;
|
|
case EADDRINUSE:
|
|
error.netError = ENetworkError::eServiceTaken;
|
|
break;
|
|
case EADDRNOTAVAIL:
|
|
case EHOSTUNREACH:
|
|
case EHOSTDOWN:
|
|
error.netError = ENetworkError::eEndpointRefused;
|
|
break;
|
|
case ECONNREFUSED:
|
|
error.netError = ENetworkError::eServiceRefused;
|
|
break;
|
|
case ECONNABORTED:
|
|
error.netError = ENetworkError::eConnectionReset;
|
|
break;
|
|
case ENETUNREACH:
|
|
error.netError = ENetworkError::eUnreachable;
|
|
break;
|
|
case EMSGSIZE: // "However, the receiving program did not have
|
|
// "enough free file descriptor slots to accept them" - recvfrom
|
|
error.netError = ENetworkError::eResourceConstraint;
|
|
break;
|
|
}
|
|
#endif
|
|
}
|
|
|
|
static AuString StringifyOSError(AuUInt32 dwErrorCode)
|
|
{
|
|
#if defined(AURORA_IS_MODERNNT_DERIVED)
|
|
LPSTR messageBuffer {};
|
|
size_t size = ::FormatMessageA(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
|
|
NULL,
|
|
dwErrorCode,
|
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
|
|
(LPSTR)&messageBuffer,
|
|
0,
|
|
NULL);
|
|
if (!messageBuffer)
|
|
{
|
|
return {};
|
|
}
|
|
|
|
AuString message(messageBuffer, size);
|
|
|
|
::LocalFree(messageBuffer);
|
|
return message;
|
|
#else
|
|
return ::strerror(dwErrorCode);
|
|
#endif
|
|
}
|
|
|
|
AUKN_SYM AuString NetErrorToExtendedString(const NetError &error)
|
|
{
|
|
return fmt::format("error: {}, code: 0x{:x}, os: {}", NetErrorToString(error), error.osError, StringifyOSError(error.osError));
|
|
}
|
|
|
|
AUKN_SYM AuString NetErrorToString(const NetError &error)
|
|
{
|
|
return ENetworkErrorToString(error.netError);
|
|
}
|
|
} |