IXWebSocket/ws/ws_broadcast_server.cpp

97 lines
3.7 KiB
C++
Raw Permalink Normal View History

/*
* ws_broadcast_server.cpp
* Author: Benjamin Sergeant
* Copyright (c) 2018 Machine Zone, Inc. All rights reserved.
*/
#include <ixwebsocket/IXWebSocketServer.h>
#include <spdlog/spdlog.h>
2019-12-30 17:46:18 +01:00
#include <sstream>
namespace ix
{
int ws_broadcast_server_main(int port,
const std::string& hostname,
const ix::SocketTLSOptions& tlsOptions)
{
spdlog::info("Listening on {}:{}", hostname, port);
ix::WebSocketServer server(port, hostname);
server.setTLSOptions(tlsOptions);
2019-09-23 19:25:23 +02:00
server.setOnConnectionCallback([&server](std::shared_ptr<WebSocket> webSocket,
std::shared_ptr<ConnectionState> connectionState) {
webSocket->setOnMessageCallback([webSocket, connectionState, &server](
const WebSocketMessagePtr& msg) {
if (msg->type == ix::WebSocketMessageType::Open)
{
spdlog::info("New connection");
spdlog::info("id: {}", connectionState->getId());
spdlog::info("Uri: {}", msg->openInfo.uri);
spdlog::info("Headers:");
2019-09-23 19:25:23 +02:00
for (auto it : msg->openInfo.headers)
{
spdlog::info("{}: {}", it.first, it.second);
2019-09-23 19:25:23 +02:00
}
}
else if (msg->type == ix::WebSocketMessageType::Close)
{
spdlog::info("Closed connection: code {} reason {}",
2019-12-30 17:46:18 +01:00
msg->closeInfo.code,
msg->closeInfo.reason);
2019-09-23 19:25:23 +02:00
}
else if (msg->type == ix::WebSocketMessageType::Error)
{
std::stringstream ss;
ss << "Connection error: " << msg->errorInfo.reason << std::endl;
ss << "#retries: " << msg->errorInfo.retries << std::endl;
ss << "Wait time(ms): " << msg->errorInfo.wait_time << std::endl;
ss << "HTTP Status: " << msg->errorInfo.http_status << std::endl;
spdlog::info(ss.str());
2019-09-23 19:25:23 +02:00
}
else if (msg->type == ix::WebSocketMessageType::Fragment)
{
spdlog::info("Received message fragment");
2019-09-23 19:25:23 +02:00
}
else if (msg->type == ix::WebSocketMessageType::Message)
{
spdlog::info("Received {} bytes", msg->wireSize);
2019-09-23 19:25:23 +02:00
for (auto&& client : server.getClients())
{
if (client != webSocket)
{
2019-09-23 19:25:23 +02:00
client->send(msg->str, msg->binary, [](int current, int total) -> bool {
spdlog::info("Step {} out of {}", current, total);
2019-09-23 19:25:23 +02:00
return true;
});
2019-09-23 19:25:23 +02:00
do
{
2019-09-23 19:25:23 +02:00
size_t bufferedAmount = client->bufferedAmount();
spdlog::info("{} bytes left to be sent", bufferedAmount);
2020-01-09 22:30:08 +01:00
std::chrono::duration<double, std::milli> duration(500);
2019-09-23 19:25:23 +02:00
std::this_thread::sleep_for(duration);
} while (client->bufferedAmount() != 0);
}
}
2019-09-23 19:25:23 +02:00
}
});
});
auto res = server.listen();
if (!res.first)
{
spdlog::info(res.second);
return 1;
}
server.start();
server.wait();
return 0;
}
2019-09-23 19:25:23 +02:00
} // namespace ix