2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
42#include "core/State.h"
43#include "core/socket/stream/SocketAcceptor.h"
45#ifndef DOXYGEN_SHOULD_SKIP_THIS
47#include "log/Logger.h"
48#include "utils/PreserveErrno.h"
56namespace core::socket::
stream {
58 template <
typename SocketAddress,
typename PhysicalSocket,
typename Config>
60 typename SocketAddress::SockAddr localSockAddr;
61 typename SocketAddress::SockLen localSockAddrLen =
sizeof(
typename SocketAddress::SockAddr);
63 SocketAddress localPeerAddress;
64 if (physicalSocket.getSockName(localSockAddr, localSockAddrLen) == 0) {
66 localPeerAddress = config->Local::getSocketAddress(localSockAddr, localSockAddrLen);
67 LOG(TRACE) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
68 <<
" PeerAddress (local): " << localPeerAddress.toString();
69 }
catch (
const typename SocketAddress::BadSocketAddress& badSocketAddress) {
70 LOG(WARNING) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
71 <<
" PeerAddress (local): " << badSocketAddress.what();
74 PLOG(WARNING) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
75 <<
" PeerAddress (local) not retrievable";
78 return localPeerAddress;
81 template <
typename SocketAddress,
typename PhysicalSocket,
typename Config>
83 typename SocketAddress::SockAddr remoteSockAddr;
84 typename SocketAddress::SockLen remoteSockAddrLen =
sizeof(
typename SocketAddress::SockAddr);
86 SocketAddress remotePeerAddress;
87 if (physicalSocket.getPeerName(remoteSockAddr, remoteSockAddrLen) == 0) {
89 remotePeerAddress = config->Remote::getSocketAddress(remoteSockAddr, remoteSockAddrLen);
90 LOG(TRACE) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
91 <<
" PeerAddress (remote): " << remotePeerAddress.toString();
92 }
catch (
const typename SocketAddress::BadSocketAddress& badSocketAddress) {
93 LOG(WARNING) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
94 <<
" PeerAddress (remote): " << badSocketAddress.what();
97 PLOG(WARNING) << config->getInstanceName() <<
" [" << physicalSocket.getFd() <<
"]" << std::setw(25)
98 <<
" PeerAddress (remote) not retrievable";
101 return remotePeerAddress;
104 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
107 const std::function<
void(SocketConnection*)>& onConnect,
108 const std::function<
void(SocketConnection*)>& onConnected,
109 const std::function<
void(SocketConnection*)>& onDisconnect,
110 const std::function<
void(
const SocketAddress&, core::socket::
State)>& onStatus,
111 const std::shared_ptr<Config>& config)
128 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
146 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
150 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
152 if (!
config->getDisabled()) {
154 LOG(TRACE) <<
config->getInstanceName() <<
" Starting";
158 core::socket::
State state = core::socket::STATE_OK;
166 PLOG(DEBUG) <<
config->getInstanceName() <<
" open: '" <<
localAddress.toString() <<
"'";
168 state = core::socket::STATE_ERROR;
171 PLOG(DEBUG) <<
config->getInstanceName() <<
" open: '" <<
localAddress.toString() <<
"'";
173 state = core::socket::STATE_FATAL;
179 PLOG(DEBUG) <<
config->getInstanceName() <<
" bind: '" <<
localAddress.toString() <<
"'";
181 state = core::socket::STATE_ERROR;
184 PLOG(DEBUG) <<
config->getInstanceName() <<
" bind: '" <<
localAddress.toString() <<
"'";
186 state = core::socket::STATE_FATAL;
192 PLOG(DEBUG) <<
config->getInstanceName() <<
" listen: '" <<
localAddress.toString() <<
"'";
194 state = core::socket::STATE_ERROR;
197 PLOG(DEBUG) <<
config->getInstanceName() <<
" listen: '" <<
localAddress.toString() <<
"'";
199 state = core::socket::STATE_FATAL;
204 LOG(DEBUG) <<
config->getInstanceName() <<
" enabled: '" <<
localAddress.toString() <<
"' success";
206 LOG(DEBUG) <<
config->getInstanceName() <<
" enabled: '" <<
localAddress.toString() <<
"' failed";
208 state = core::socket::STATE(core::socket::STATE_FATAL, ECANCELED,
"SocketAcceptor not enabled");
216 LOG(DEBUG) <<
config->getInstanceName() <<
" using next SocketAddress: '"
217 <<
config->Local::getSocketAddress().toString() <<
"'";
223 }
catch (
const typename SocketAddress::BadSocketAddress& badSocketAddress) {
224 LOG(DEBUG) <<
config->getInstanceName() <<
" " << badSocketAddress.what();
226 onStatus({}, core::socket::STATE(badSocketAddress.getState(), badSocketAddress.getErrnum(), badSocketAddress.what()));
229 LOG(DEBUG) <<
config->getInstanceName() <<
" disabled";
231 onStatus({}, core::socket::STATE_DISABLED);
241 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
243 int acceptsPerTick =
config->getAcceptsPerTick();
246 PhysicalServerSocket connectedPhysicalSocket(
physicalServerSocket.accept4(PhysicalServerSocket::Flags::NONBLOCK),
248 if (connectedPhysicalSocket.isValid()) {
249 LOG(DEBUG) <<
"[" << connectedPhysicalSocket.getFd() <<
" ]" <<
config->getInstanceName() <<
": accept success: '"
250 << connectedPhysicalSocket.getBindAddress().toString() <<
"'";
252 SocketConnection* socketConnection =
253 new SocketConnection(
config->getInstanceName(),
254 std::move(connectedPhysicalSocket),
257 getLocalSocketAddress<SocketAddress>(connectedPhysicalSocket,
config),
258 getRemoteSocketAddress<SocketAddress>(connectedPhysicalSocket,
config),
260 config->getWriteTimeout(),
261 config->getReadBlockSize(),
262 config->getWriteBlockSize(),
263 config->getTerminateTimeout());
267 }
else if (errno != EINTR && errno != EAGAIN && errno != EWOULDBLOCK) {
271 }
while (--acceptsPerTick > 0);
274 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
279 template <
typename PhysicalSocketServer,
typename Config,
template <
typename PhysicalSocketServerT>
typename SocketConnection>
void setTimeout(const utils::Timeval &timeout)
static void atNextTick(const std::function< void(void)> &callBack)
static constexpr int NO_RETRY
State operator|(int state)
SocketAcceptor(const std::shared_ptr< core::socket::stream::SocketContextFactory > &socketContextFactory, const std::function< void(SocketConnection *)> &onConnect, const std::function< void(SocketConnection *)> &onConnected, const std::function< void(SocketConnection *)> &onDisconnect, const std::function< void(const SocketAddress &, core::socket::State)> &onStatus, const std::shared_ptr< Config > &config)
std::function< void(SocketConnection *)> onConnected
SocketAcceptor(const SocketAcceptor &socketAcceptor)
SocketAddress localAddress
std::function< void(SocketConnection *)> onConnect
std::function< void(SocketConnection *)> onDisconnect
std::shared_ptr< core::socket::stream::SocketContextFactory > socketContextFactory
void unobservedEvent() final
std::shared_ptr< Config > config
virtual void useNextSocketAddress()=0
~SocketAcceptor() override
PhysicalServerSocket physicalServerSocket
std::function< void(const SocketAddress &, core::socket::State)> onStatus
void useNextSocketAddress() override
SocketAcceptor(const SocketAcceptor &socketAcceptor)
SocketAcceptor(const std::shared_ptr< core::socket::stream::SocketContextFactory > &socketContextFactory, const std::function< void(SocketConnection *)> &onConnect, const std::function< void(SocketConnection *)> &onConnected, const std::function< void(SocketConnection *)> &onDisconnect, const std::function< void(const SocketAddress &, core::socket::State)> &onStatus, const std::shared_ptr< Config > &config)
SocketAddress getRemoteSocketAddress(PhysicalSocket &physicalSocket, Config &config)
SocketAddress getLocalSocketAddress(PhysicalSocket &physicalSocket, Config &config)