IXWebSocket/ixwebsocket/IXWebSocketServer.cpp

125 lines
3.3 KiB
C++
Raw Normal View History

2018-12-30 08:15:27 +01:00
/*
* IXWebSocketServer.cpp
* Author: Benjamin Sergeant
* Copyright (c) 2018 Machine Zone, Inc. All rights reserved.
*/
#include "IXWebSocketServer.h"
2019-09-23 19:25:23 +02:00
#include "IXNetSystem.h"
#include "IXSocketConnect.h"
#include "IXWebSocket.h"
#include "IXWebSocketTransport.h"
2019-01-01 22:47:25 +01:00
#include <future>
2019-09-23 19:25:23 +02:00
#include <sstream>
2019-01-02 02:13:26 +01:00
#include <string.h>
2018-12-30 08:15:27 +01:00
namespace ix
2018-12-30 08:15:27 +01:00
{
2019-01-04 03:33:08 +01:00
const int WebSocketServer::kDefaultHandShakeTimeoutSecs(3); // 3 seconds
const bool WebSocketServer::kDefaultEnablePong(true);
WebSocketServer::WebSocketServer(int port,
const std::string& host,
int backlog,
2019-01-04 03:33:08 +01:00
size_t maxConnections,
int handshakeTimeoutSecs,
int addressFamily)
: SocketServer(port, host, backlog, maxConnections, addressFamily)
2019-09-23 19:25:23 +02:00
, _handshakeTimeoutSecs(handshakeTimeoutSecs)
, _enablePong(kDefaultEnablePong)
2018-12-30 08:15:27 +01:00
{
}
WebSocketServer::~WebSocketServer()
{
stop();
2018-12-30 08:15:27 +01:00
}
void WebSocketServer::stop()
{
stopAcceptingConnections();
auto clients = getClients();
for (auto client : clients)
{
client->close();
}
SocketServer::stop();
}
void WebSocketServer::enablePong()
{
_enablePong = true;
}
void WebSocketServer::disablePong()
{
_enablePong = false;
}
void WebSocketServer::setOnConnectionCallback(const OnConnectionCallback& callback)
{
_onConnectionCallback = callback;
}
void WebSocketServer::handleConnection(std::shared_ptr<Socket> socket,
std::shared_ptr<ConnectionState> connectionState)
{
auto webSocket = std::make_shared<WebSocket>();
_onConnectionCallback(webSocket, connectionState);
webSocket->disableAutomaticReconnection();
if (_enablePong)
webSocket->enablePong();
else
webSocket->disablePong();
// Add this client to our client set
{
std::lock_guard<std::mutex> lock(_clientsMutex);
_clients.insert(webSocket);
}
2019-01-01 22:47:25 +01:00
auto status = webSocket->connectToSocket(socket, _handshakeTimeoutSecs);
if (status.success)
{
// Process incoming messages and execute callbacks
// until the connection is closed
webSocket->run();
}
else
2019-01-01 22:47:25 +01:00
{
std::stringstream ss;
2019-09-23 19:25:23 +02:00
ss << "WebSocketServer::handleConnection() HTTP status: " << status.http_status
<< " error: " << status.errorStr;
logError(ss.str());
2019-01-01 22:47:25 +01:00
}
// Remove this client from our client set
{
std::lock_guard<std::mutex> lock(_clientsMutex);
if (_clients.erase(webSocket) != 1)
{
logError("Cannot delete client");
}
}
connectionState->setTerminated();
}
2019-01-01 22:47:25 +01:00
std::set<std::shared_ptr<WebSocket>> WebSocketServer::getClients()
{
std::lock_guard<std::mutex> lock(_clientsMutex);
return _clients;
2018-12-30 08:15:27 +01:00
}
size_t WebSocketServer::getConnectedClientsCount()
{
std::lock_guard<std::mutex> lock(_clientsMutex);
return _clients.size();
}
2019-09-23 19:25:23 +02:00
} // namespace ix