add stub code for ws proxy server
This commit is contained in:
parent
4e717abdb8
commit
0841fcec44
@ -55,6 +55,7 @@ add_executable(ws
|
|||||||
ws_cobra_metrics_to_redis.cpp
|
ws_cobra_metrics_to_redis.cpp
|
||||||
ws_httpd.cpp
|
ws_httpd.cpp
|
||||||
ws_autobahn.cpp
|
ws_autobahn.cpp
|
||||||
|
ws_proxy_server.cpp
|
||||||
ws.cpp)
|
ws.cpp)
|
||||||
|
|
||||||
target_link_libraries(ws ixsnake)
|
target_link_libraries(ws ixsnake)
|
||||||
|
12
ws/ws.cpp
12
ws/ws.cpp
@ -72,6 +72,7 @@ int main(int argc, char** argv)
|
|||||||
std::string redisPassword;
|
std::string redisPassword;
|
||||||
std::string appsConfigPath("appsConfig.json");
|
std::string appsConfigPath("appsConfig.json");
|
||||||
std::string subprotocol;
|
std::string subprotocol;
|
||||||
|
std::string remoteHost;
|
||||||
ix::SocketTLSOptions tlsOptions;
|
ix::SocketTLSOptions tlsOptions;
|
||||||
std::string ciphers;
|
std::string ciphers;
|
||||||
std::string redirectUrl;
|
std::string redirectUrl;
|
||||||
@ -99,6 +100,7 @@ int main(int argc, char** argv)
|
|||||||
int delayMs = -1;
|
int delayMs = -1;
|
||||||
int count = 1;
|
int count = 1;
|
||||||
int jobs = 4;
|
int jobs = 4;
|
||||||
|
int remotePort = 8008;
|
||||||
uint32_t maxWaitBetweenReconnectionRetries;
|
uint32_t maxWaitBetweenReconnectionRetries;
|
||||||
|
|
||||||
auto addTLSOptions = [&tlsOptions, &verifyNone](CLI::App* app) {
|
auto addTLSOptions = [&tlsOptions, &verifyNone](CLI::App* app) {
|
||||||
@ -304,6 +306,12 @@ int main(int argc, char** argv)
|
|||||||
redisServerApp->add_option("--port", port, "Port");
|
redisServerApp->add_option("--port", port, "Port");
|
||||||
redisServerApp->add_option("--host", hostname, "Hostname");
|
redisServerApp->add_option("--host", hostname, "Hostname");
|
||||||
|
|
||||||
|
CLI::App* proxyServerApp = app.add_subcommand("proxy_server", "Proxy server");
|
||||||
|
proxyServerApp->add_option("--port", port, "Port");
|
||||||
|
proxyServerApp->add_option("--host", hostname, "Hostname");
|
||||||
|
proxyServerApp->add_option("--remote_port", remotePort, "Remote Port");
|
||||||
|
proxyServerApp->add_option("--remote_host", remoteHost, "Remote Hostname");
|
||||||
|
|
||||||
CLI11_PARSE(app, argc, argv);
|
CLI11_PARSE(app, argc, argv);
|
||||||
|
|
||||||
// pid file handling
|
// pid file handling
|
||||||
@ -442,6 +450,10 @@ int main(int argc, char** argv)
|
|||||||
{
|
{
|
||||||
ret = ix::ws_redis_server_main(port, hostname);
|
ret = ix::ws_redis_server_main(port, hostname);
|
||||||
}
|
}
|
||||||
|
else if (app.got_subcommand("proxy_server"))
|
||||||
|
{
|
||||||
|
ret = ix::ws_proxy_server_main(port, hostname, tlsOptions, remoteHost, remotePort);
|
||||||
|
}
|
||||||
else if (version)
|
else if (version)
|
||||||
{
|
{
|
||||||
std::cout << "ws " << ix::userAgent() << std::endl;
|
std::cout << "ws " << ix::userAgent() << std::endl;
|
||||||
|
6
ws/ws.h
6
ws/ws.h
@ -142,4 +142,10 @@ namespace ix
|
|||||||
int ws_autobahn_main(const std::string& url, bool quiet);
|
int ws_autobahn_main(const std::string& url, bool quiet);
|
||||||
|
|
||||||
int ws_redis_server_main(int port, const std::string& hostname);
|
int ws_redis_server_main(int port, const std::string& hostname);
|
||||||
|
|
||||||
|
int ws_proxy_server_main(int port,
|
||||||
|
const std::string& hostname,
|
||||||
|
const ix::SocketTLSOptions& tlsOptions,
|
||||||
|
const std::string& remoteHost,
|
||||||
|
int remotePort);
|
||||||
} // namespace ix
|
} // namespace ix
|
||||||
|
75
ws/ws_proxy_server.cpp
Normal file
75
ws/ws_proxy_server.cpp
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
/*
|
||||||
|
* ws_proxy_server.cpp
|
||||||
|
* Author: Benjamin Sergeant
|
||||||
|
* Copyright (c) 2018 Machine Zone, Inc. All rights reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <ixwebsocket/IXWebSocketServer.h>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
namespace ix
|
||||||
|
{
|
||||||
|
int ws_proxy_server_main(int port,
|
||||||
|
const std::string& hostname,
|
||||||
|
const ix::SocketTLSOptions& tlsOptions,
|
||||||
|
const std::string& remoteHost,
|
||||||
|
int remotePort)
|
||||||
|
{
|
||||||
|
std::cout << "Listening on " << hostname << ":" << port << std::endl;
|
||||||
|
|
||||||
|
ix::WebSocketServer server(port, hostname);
|
||||||
|
server.setTLSOptions(tlsOptions);
|
||||||
|
|
||||||
|
server.setOnConnectionCallback(
|
||||||
|
[remoteHost, remotePort](std::shared_ptr<ix::WebSocket> webSocket,
|
||||||
|
std::shared_ptr<ConnectionState> connectionState) {
|
||||||
|
webSocket->setOnMessageCallback(
|
||||||
|
[webSocket, connectionState, remoteHost, remotePort](const WebSocketMessagePtr& msg) {
|
||||||
|
if (msg->type == ix::WebSocketMessageType::Open)
|
||||||
|
{
|
||||||
|
std::cerr << "New connection" << std::endl;
|
||||||
|
std::cerr << "id: " << connectionState->getId() << std::endl;
|
||||||
|
std::cerr << "Uri: " << msg->openInfo.uri << std::endl;
|
||||||
|
std::cerr << "Headers:" << std::endl;
|
||||||
|
for (auto it : msg->openInfo.headers)
|
||||||
|
{
|
||||||
|
std::cerr << it.first << ": " << it.second << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (msg->type == ix::WebSocketMessageType::Close)
|
||||||
|
{
|
||||||
|
std::cerr << "Closed connection"
|
||||||
|
<< " code " << msg->closeInfo.code << " reason "
|
||||||
|
<< msg->closeInfo.reason << std::endl;
|
||||||
|
}
|
||||||
|
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;
|
||||||
|
std::cerr << ss.str();
|
||||||
|
}
|
||||||
|
else if (msg->type == ix::WebSocketMessageType::Message)
|
||||||
|
{
|
||||||
|
std::cerr << "Received " << msg->wireSize << " bytes" << std::endl;
|
||||||
|
webSocket->send(msg->str, msg->binary);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
auto res = server.listen();
|
||||||
|
if (!res.first)
|
||||||
|
{
|
||||||
|
std::cerr << res.second << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
server.start();
|
||||||
|
server.wait();
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
} // namespace ix
|
Loading…
x
Reference in New Issue
Block a user