2019-02-22 06:24:53 +01:00
|
|
|
/*
|
|
|
|
* ws.cpp
|
|
|
|
* Author: Benjamin Sergeant
|
2019-03-01 06:54:03 +01:00
|
|
|
* Copyright (c) 2019 Machine Zone, Inc. All rights reserved.
|
2019-02-22 06:24:53 +01:00
|
|
|
*/
|
|
|
|
|
2019-03-01 06:54:03 +01:00
|
|
|
//
|
|
|
|
// Main driver for websocket utilities
|
|
|
|
//
|
|
|
|
#include "ws.h"
|
|
|
|
|
2019-02-22 06:24:53 +01:00
|
|
|
#include <cli11/CLI11.hpp>
|
2019-09-23 19:25:23 +02:00
|
|
|
#include <fstream>
|
2020-03-12 20:15:56 +01:00
|
|
|
#include <ixbots/IXCobraToSentryBot.h>
|
|
|
|
#include <ixbots/IXCobraToStatsdBot.h>
|
2020-04-17 06:58:10 +02:00
|
|
|
#include <ixbots/IXCobraToStdoutBot.h>
|
2019-05-09 03:53:09 +02:00
|
|
|
#include <ixcore/utils/IXCoreLogger.h>
|
2020-03-13 00:27:25 +01:00
|
|
|
#include <ixsentry/IXSentryClient.h>
|
2019-09-23 19:25:23 +02:00
|
|
|
#include <ixwebsocket/IXNetSystem.h>
|
|
|
|
#include <ixwebsocket/IXSocket.h>
|
2019-10-01 02:31:33 +02:00
|
|
|
#include <ixwebsocket/IXUserAgent.h>
|
2020-04-17 18:56:09 +02:00
|
|
|
#include <spdlog/spdlog.h>
|
2020-04-24 21:47:47 +02:00
|
|
|
#include <spdlog/sinks/basic_file_sink.h>
|
2019-09-23 19:25:23 +02:00
|
|
|
#include <sstream>
|
|
|
|
#include <string>
|
2019-02-22 06:24:53 +01:00
|
|
|
|
2019-10-02 01:12:16 +02:00
|
|
|
#ifndef _WIN32
|
|
|
|
#include <signal.h>
|
2020-01-08 02:37:38 +01:00
|
|
|
#else
|
|
|
|
#include <process.h>
|
|
|
|
#define getpid _getpid
|
2019-10-02 01:12:16 +02:00
|
|
|
#endif
|
|
|
|
|
2019-05-10 00:30:44 +02:00
|
|
|
|
2019-02-22 06:24:53 +01:00
|
|
|
int main(int argc, char** argv)
|
|
|
|
{
|
2019-04-26 01:38:15 +02:00
|
|
|
ix::initNetSystem();
|
|
|
|
|
2020-04-25 00:17:50 +02:00
|
|
|
ix::CoreLogger::LogFunc logFunc = [](const char* msg, ix::LogLevel level) {
|
|
|
|
switch (level)
|
|
|
|
{
|
|
|
|
case ix::LogLevel::Debug:
|
|
|
|
{
|
|
|
|
spdlog::debug(msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ix::LogLevel::Info:
|
|
|
|
{
|
|
|
|
spdlog::info(msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ix::LogLevel::Warning:
|
|
|
|
{
|
|
|
|
spdlog::warn(msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ix::LogLevel::Error:
|
|
|
|
{
|
|
|
|
spdlog::error(msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ix::LogLevel::Critical:
|
|
|
|
{
|
|
|
|
spdlog::critical(msg);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
ix::CoreLogger::setLogFunction(logFunc);
|
2019-05-09 03:53:09 +02:00
|
|
|
|
2019-10-02 00:43:37 +02:00
|
|
|
#ifndef _WIN32
|
|
|
|
signal(SIGPIPE, SIG_IGN);
|
|
|
|
#endif
|
|
|
|
|
2019-05-11 01:27:23 +02:00
|
|
|
// Display command.
|
|
|
|
if (getenv("DEBUG"))
|
|
|
|
{
|
2019-12-25 06:55:34 +01:00
|
|
|
std::stringstream ss;
|
|
|
|
ss << "Command: ";
|
2019-05-11 01:27:23 +02:00
|
|
|
for (int i = 0; i < argc; ++i)
|
|
|
|
{
|
2019-12-25 06:55:34 +01:00
|
|
|
ss << argv[i] << " ";
|
2019-05-11 01:27:23 +02:00
|
|
|
}
|
2019-12-25 06:55:34 +01:00
|
|
|
spdlog::info(ss.str());
|
2019-05-11 01:27:23 +02:00
|
|
|
}
|
|
|
|
|
2019-09-23 19:25:23 +02:00
|
|
|
CLI::App app {"ws is a websocket tool"};
|
2019-02-22 06:24:53 +01:00
|
|
|
|
2019-05-08 22:56:36 +02:00
|
|
|
std::string url("ws://127.0.0.1:8008");
|
2019-02-22 06:24:53 +01:00
|
|
|
std::string path;
|
2019-02-23 05:49:26 +01:00
|
|
|
std::string user;
|
2019-03-01 06:54:03 +01:00
|
|
|
std::string data;
|
|
|
|
std::string headers;
|
|
|
|
std::string output;
|
2019-03-11 19:12:43 +01:00
|
|
|
std::string hostname("127.0.0.1");
|
2019-03-14 21:47:03 +01:00
|
|
|
std::string pidfile;
|
2019-03-20 22:29:02 +01:00
|
|
|
std::string channel;
|
2019-08-02 00:22:24 +02:00
|
|
|
std::string filter;
|
2020-03-14 00:06:13 +01:00
|
|
|
std::string position;
|
2019-03-20 22:29:02 +01:00
|
|
|
std::string message;
|
2019-03-26 17:33:22 +01:00
|
|
|
std::string password;
|
2019-04-09 06:52:20 +02:00
|
|
|
std::string prefix("ws.test.v0");
|
|
|
|
std::string fields;
|
2020-03-30 04:31:49 +02:00
|
|
|
std::string gauge;
|
2020-03-31 01:08:47 +02:00
|
|
|
std::string timer;
|
2019-04-12 01:03:05 +02:00
|
|
|
std::string dsn;
|
2019-04-23 02:24:01 +02:00
|
|
|
std::string redisHosts("127.0.0.1");
|
|
|
|
std::string redisPassword;
|
|
|
|
std::string appsConfigPath("appsConfig.json");
|
2019-10-13 22:37:34 +02:00
|
|
|
std::string subprotocol;
|
2019-11-15 23:30:20 +01:00
|
|
|
std::string remoteHost;
|
2019-11-26 06:08:43 +01:00
|
|
|
std::string minidump;
|
|
|
|
std::string metadata;
|
|
|
|
std::string project;
|
|
|
|
std::string key;
|
2020-04-17 18:35:47 +02:00
|
|
|
std::string logfile;
|
2019-09-30 03:29:51 +02:00
|
|
|
ix::SocketTLSOptions tlsOptions;
|
2020-03-11 18:48:27 +01:00
|
|
|
ix::CobraConfig cobraConfig;
|
2019-09-30 03:29:51 +02:00
|
|
|
std::string ciphers;
|
2019-09-26 18:10:30 +02:00
|
|
|
std::string redirectUrl;
|
2019-03-01 06:54:03 +01:00
|
|
|
bool headersOnly = false;
|
|
|
|
bool followRedirects = false;
|
|
|
|
bool verbose = false;
|
|
|
|
bool save = false;
|
2019-08-02 00:22:24 +02:00
|
|
|
bool quiet = false;
|
2020-03-09 23:25:43 +01:00
|
|
|
bool fluentd = false;
|
2019-03-01 06:54:03 +01:00
|
|
|
bool compress = false;
|
2019-04-23 02:24:01 +02:00
|
|
|
bool stress = false;
|
2019-04-29 23:31:29 +02:00
|
|
|
bool disableAutomaticReconnection = false;
|
2019-06-06 22:48:53 +02:00
|
|
|
bool disablePerMessageDeflate = false;
|
2019-06-08 18:16:33 +02:00
|
|
|
bool greetings = false;
|
2020-01-27 01:44:44 +01:00
|
|
|
bool ipv6 = false;
|
2019-07-26 00:48:45 +02:00
|
|
|
bool binaryMode = false;
|
2019-09-26 18:10:30 +02:00
|
|
|
bool redirect = false;
|
2019-10-01 02:31:33 +02:00
|
|
|
bool version = false;
|
2019-10-02 00:43:37 +02:00
|
|
|
bool verifyNone = false;
|
2020-02-01 01:55:54 +01:00
|
|
|
bool disablePong = false;
|
2019-05-08 22:56:36 +02:00
|
|
|
int port = 8008;
|
2019-03-20 22:29:02 +01:00
|
|
|
int redisPort = 6379;
|
2019-04-09 06:52:20 +02:00
|
|
|
int statsdPort = 8125;
|
2019-03-01 06:54:03 +01:00
|
|
|
int connectTimeOut = 60;
|
|
|
|
int transferTimeout = 1800;
|
|
|
|
int maxRedirects = 5;
|
2019-03-18 22:25:27 +01:00
|
|
|
int delayMs = -1;
|
2019-03-27 21:41:46 +01:00
|
|
|
int count = 1;
|
2019-08-30 21:46:35 +02:00
|
|
|
uint32_t maxWaitBetweenReconnectionRetries;
|
2019-12-26 07:15:57 +01:00
|
|
|
size_t maxQueueSize = 100;
|
2020-03-18 07:54:32 +01:00
|
|
|
int pingIntervalSecs = 30;
|
2020-04-14 04:03:53 +02:00
|
|
|
int runtime = -1; // run indefinitely
|
2019-02-22 06:24:53 +01:00
|
|
|
|
2019-10-02 00:43:37 +02:00
|
|
|
auto addTLSOptions = [&tlsOptions, &verifyNone](CLI::App* app) {
|
2019-09-30 03:29:51 +02:00
|
|
|
app->add_option(
|
|
|
|
"--cert-file", tlsOptions.certFile, "Path to the (PEM format) TLS cert file")
|
|
|
|
->check(CLI::ExistingPath);
|
|
|
|
app->add_option("--key-file", tlsOptions.keyFile, "Path to the (PEM format) TLS key file")
|
|
|
|
->check(CLI::ExistingPath);
|
|
|
|
app->add_option("--ca-file", tlsOptions.caFile, "Path to the (PEM format) ca roots file")
|
|
|
|
->check(CLI::ExistingPath);
|
|
|
|
app->add_option("--ciphers",
|
|
|
|
tlsOptions.ciphers,
|
|
|
|
"A (comma/space/colon) separated list of ciphers to use for TLS");
|
2019-10-02 00:43:37 +02:00
|
|
|
app->add_flag("--tls", tlsOptions.tls, "Enable TLS (server only)");
|
|
|
|
app->add_flag("--verify_none", verifyNone, "Disable peer cert verification");
|
2019-09-30 03:29:51 +02:00
|
|
|
};
|
|
|
|
|
2020-03-11 18:48:27 +01:00
|
|
|
auto addCobraConfig = [&cobraConfig](CLI::App* app) {
|
|
|
|
app->add_option("--appkey", cobraConfig.appkey, "Appkey")->required();
|
|
|
|
app->add_option("--endpoint", cobraConfig.endpoint, "Endpoint")->required();
|
|
|
|
app->add_option("--rolename", cobraConfig.rolename, "Role name")->required();
|
|
|
|
app->add_option("--rolesecret", cobraConfig.rolesecret, "Role secret")->required();
|
|
|
|
};
|
|
|
|
|
2020-01-04 23:37:53 +01:00
|
|
|
app.add_flag("--version", version, "Print ws version");
|
2020-04-17 18:35:47 +02:00
|
|
|
app.add_option("--logfile", logfile, "path where all logs will be redirected");
|
2019-10-01 02:31:33 +02:00
|
|
|
|
2019-02-22 06:24:53 +01:00
|
|
|
CLI::App* sendApp = app.add_subcommand("send", "Send a file");
|
2020-04-17 18:35:47 +02:00
|
|
|
sendApp->fallthrough();
|
2019-02-22 06:24:53 +01:00
|
|
|
sendApp->add_option("url", url, "Connection url")->required();
|
2019-03-01 06:54:03 +01:00
|
|
|
sendApp->add_option("path", path, "Path to the file to send")
|
2019-09-23 19:25:23 +02:00
|
|
|
->required()
|
|
|
|
->check(CLI::ExistingPath);
|
2019-03-19 04:37:33 +01:00
|
|
|
sendApp->add_option("--pidfile", pidfile, "Pid file");
|
2020-01-05 00:08:36 +01:00
|
|
|
sendApp->add_flag("-x", disablePerMessageDeflate, "Disable per message deflate");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(sendApp);
|
2019-03-18 22:25:27 +01:00
|
|
|
|
2019-02-22 06:24:53 +01:00
|
|
|
CLI::App* receiveApp = app.add_subcommand("receive", "Receive a file");
|
2020-04-17 18:35:47 +02:00
|
|
|
receiveApp->fallthrough();
|
2019-02-22 06:24:53 +01:00
|
|
|
receiveApp->add_option("url", url, "Connection url")->required();
|
2019-09-23 19:25:23 +02:00
|
|
|
receiveApp->add_option("--delay",
|
|
|
|
delayMs,
|
|
|
|
"Delay (ms) to wait after receiving a fragment"
|
|
|
|
" to artificially slow down the receiver");
|
2019-03-19 04:37:33 +01:00
|
|
|
receiveApp->add_option("--pidfile", pidfile, "Pid file");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(receiveApp);
|
2019-02-22 06:24:53 +01:00
|
|
|
|
|
|
|
CLI::App* transferApp = app.add_subcommand("transfer", "Broadcasting server");
|
2020-04-17 18:35:47 +02:00
|
|
|
transferApp->fallthrough();
|
2019-02-22 06:24:53 +01:00
|
|
|
transferApp->add_option("--port", port, "Connection url");
|
2019-03-14 07:09:45 +01:00
|
|
|
transferApp->add_option("--host", hostname, "Hostname");
|
2019-03-14 21:47:03 +01:00
|
|
|
transferApp->add_option("--pidfile", pidfile, "Pid file");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(transferApp);
|
2019-02-22 06:24:53 +01:00
|
|
|
|
2019-02-23 05:49:26 +01:00
|
|
|
CLI::App* connectApp = app.add_subcommand("connect", "Connect to a remote server");
|
2020-04-17 18:35:47 +02:00
|
|
|
connectApp->fallthrough();
|
2019-02-23 05:49:26 +01:00
|
|
|
connectApp->add_option("url", url, "Connection url")->required();
|
2019-08-26 19:19:09 +02:00
|
|
|
connectApp->add_option("-H", headers, "Header")->join();
|
2019-04-29 23:31:29 +02:00
|
|
|
connectApp->add_flag("-d", disableAutomaticReconnection, "Disable Automatic Reconnection");
|
2019-06-06 22:48:53 +02:00
|
|
|
connectApp->add_flag("-x", disablePerMessageDeflate, "Disable per message deflate");
|
2019-07-26 00:48:45 +02:00
|
|
|
connectApp->add_flag("-b", binaryMode, "Send in binary mode");
|
2019-09-23 19:25:23 +02:00
|
|
|
connectApp->add_option("--max_wait",
|
|
|
|
maxWaitBetweenReconnectionRetries,
|
|
|
|
"Max Wait Time between reconnection retries");
|
2020-03-21 01:00:18 +01:00
|
|
|
connectApp->add_option("--ping_interval", pingIntervalSecs, "Interval between sending pings");
|
2019-10-13 22:37:34 +02:00
|
|
|
connectApp->add_option("--subprotocol", subprotocol, "Subprotocol");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(connectApp);
|
2019-02-23 05:49:26 +01:00
|
|
|
|
|
|
|
CLI::App* chatApp = app.add_subcommand("chat", "Group chat");
|
2020-04-17 18:35:47 +02:00
|
|
|
chatApp->fallthrough();
|
2019-02-23 05:49:26 +01:00
|
|
|
chatApp->add_option("url", url, "Connection url")->required();
|
|
|
|
chatApp->add_option("user", user, "User name")->required();
|
|
|
|
|
2019-02-23 06:13:56 +01:00
|
|
|
CLI::App* echoServerApp = app.add_subcommand("echo_server", "Echo server");
|
2020-04-17 18:35:47 +02:00
|
|
|
echoServerApp->fallthrough();
|
2019-03-14 07:09:45 +01:00
|
|
|
echoServerApp->add_option("--port", port, "Port");
|
|
|
|
echoServerApp->add_option("--host", hostname, "Hostname");
|
2019-06-08 18:16:33 +02:00
|
|
|
echoServerApp->add_flag("-g", greetings, "Verbose");
|
2020-01-27 01:44:44 +01:00
|
|
|
echoServerApp->add_flag("-6", ipv6, "IpV6");
|
2020-02-19 06:38:28 +01:00
|
|
|
echoServerApp->add_flag("-x", disablePerMessageDeflate, "Disable per message deflate");
|
2020-03-18 08:01:57 +01:00
|
|
|
echoServerApp->add_flag("-p", disablePong, "Disable sending PONG in response to PING");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(echoServerApp);
|
2019-02-23 06:13:56 +01:00
|
|
|
|
|
|
|
CLI::App* broadcastServerApp = app.add_subcommand("broadcast_server", "Broadcasting server");
|
2020-04-17 18:35:47 +02:00
|
|
|
broadcastServerApp->fallthrough();
|
2019-03-14 07:09:45 +01:00
|
|
|
broadcastServerApp->add_option("--port", port, "Port");
|
|
|
|
broadcastServerApp->add_option("--host", hostname, "Hostname");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(broadcastServerApp);
|
2019-02-23 06:13:56 +01:00
|
|
|
|
2019-02-23 06:47:57 +01:00
|
|
|
CLI::App* pingPongApp = app.add_subcommand("ping", "Ping pong");
|
2020-04-17 18:35:47 +02:00
|
|
|
pingPongApp->fallthrough();
|
2019-02-23 06:47:57 +01:00
|
|
|
pingPongApp->add_option("url", url, "Connection url")->required();
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(pingPongApp);
|
2019-02-23 06:47:57 +01:00
|
|
|
|
2019-03-01 06:54:03 +01:00
|
|
|
CLI::App* httpClientApp = app.add_subcommand("curl", "HTTP Client");
|
2020-04-17 18:35:47 +02:00
|
|
|
httpClientApp->fallthrough();
|
2019-03-01 06:54:03 +01:00
|
|
|
httpClientApp->add_option("url", url, "Connection url")->required();
|
|
|
|
httpClientApp->add_option("-d", data, "Form data")->join();
|
|
|
|
httpClientApp->add_option("-F", data, "Form data")->join();
|
|
|
|
httpClientApp->add_option("-H", headers, "Header")->join();
|
|
|
|
httpClientApp->add_option("--output", output, "Output file");
|
|
|
|
httpClientApp->add_flag("-I", headersOnly, "Send a HEAD request");
|
|
|
|
httpClientApp->add_flag("-L", followRedirects, "Follow redirects");
|
|
|
|
httpClientApp->add_option("--max-redirects", maxRedirects, "Max Redirects");
|
|
|
|
httpClientApp->add_flag("-v", verbose, "Verbose");
|
|
|
|
httpClientApp->add_flag("-O", save, "Save output to disk");
|
|
|
|
httpClientApp->add_flag("--compress", compress, "Enable gzip compression");
|
|
|
|
httpClientApp->add_option("--connect-timeout", connectTimeOut, "Connection timeout");
|
|
|
|
httpClientApp->add_option("--transfer-timeout", transferTimeout, "Transfer timeout");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(httpClientApp);
|
2019-03-01 06:54:03 +01:00
|
|
|
|
2019-03-20 22:29:02 +01:00
|
|
|
CLI::App* redisPublishApp = app.add_subcommand("redis_publish", "Redis publisher");
|
2020-04-17 18:35:47 +02:00
|
|
|
redisPublishApp->fallthrough();
|
2019-03-20 22:29:02 +01:00
|
|
|
redisPublishApp->add_option("--port", redisPort, "Port");
|
|
|
|
redisPublishApp->add_option("--host", hostname, "Hostname");
|
2019-03-26 17:33:22 +01:00
|
|
|
redisPublishApp->add_option("--password", password, "Password");
|
2019-03-20 22:29:02 +01:00
|
|
|
redisPublishApp->add_option("channel", channel, "Channel")->required();
|
|
|
|
redisPublishApp->add_option("message", message, "Message")->required();
|
2019-03-27 21:41:46 +01:00
|
|
|
redisPublishApp->add_option("-c", count, "Count");
|
2019-03-20 22:29:02 +01:00
|
|
|
|
|
|
|
CLI::App* redisSubscribeApp = app.add_subcommand("redis_subscribe", "Redis subscriber");
|
2020-04-17 18:35:47 +02:00
|
|
|
redisSubscribeApp->fallthrough();
|
2019-03-20 22:29:02 +01:00
|
|
|
redisSubscribeApp->add_option("--port", redisPort, "Port");
|
|
|
|
redisSubscribeApp->add_option("--host", hostname, "Hostname");
|
2019-03-26 17:33:22 +01:00
|
|
|
redisSubscribeApp->add_option("--password", password, "Password");
|
2019-03-20 22:29:02 +01:00
|
|
|
redisSubscribeApp->add_option("channel", channel, "Channel")->required();
|
|
|
|
redisSubscribeApp->add_flag("-v", verbose, "Verbose");
|
2019-03-27 21:41:46 +01:00
|
|
|
redisSubscribeApp->add_option("--pidfile", pidfile, "Pid file");
|
2019-03-20 22:29:02 +01:00
|
|
|
|
2019-04-09 06:52:20 +02:00
|
|
|
CLI::App* cobraSubscribeApp = app.add_subcommand("cobra_subscribe", "Cobra subscriber");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobraSubscribeApp->fallthrough();
|
2019-11-29 00:16:39 +01:00
|
|
|
cobraSubscribeApp->add_option("--channel", channel, "Channel")->required();
|
2019-04-09 06:52:20 +02:00
|
|
|
cobraSubscribeApp->add_option("--pidfile", pidfile, "Pid file");
|
2019-08-02 00:22:24 +02:00
|
|
|
cobraSubscribeApp->add_option("--filter", filter, "Stream SQL Filter");
|
2020-03-14 00:06:13 +01:00
|
|
|
cobraSubscribeApp->add_option("--position", position, "Stream position");
|
2019-08-02 00:22:24 +02:00
|
|
|
cobraSubscribeApp->add_flag("-q", quiet, "Quiet / only display stats");
|
2020-03-09 23:25:43 +01:00
|
|
|
cobraSubscribeApp->add_flag("--fluentd", fluentd, "Write fluentd prefix");
|
2020-04-14 04:03:53 +02:00
|
|
|
cobraSubscribeApp->add_option("--runtime", runtime, "Runtime in seconds");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobraSubscribeApp);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobraSubscribeApp);
|
2019-04-09 06:52:20 +02:00
|
|
|
|
2019-04-21 20:16:33 +02:00
|
|
|
CLI::App* cobraPublish = app.add_subcommand("cobra_publish", "Cobra publisher");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobraPublish->fallthrough();
|
2019-11-29 00:16:39 +01:00
|
|
|
cobraPublish->add_option("--channel", channel, "Channel")->required();
|
2019-04-21 20:16:33 +02:00
|
|
|
cobraPublish->add_option("--pidfile", pidfile, "Pid file");
|
|
|
|
cobraPublish->add_option("path", path, "Path to the file to send")
|
2019-09-23 19:25:23 +02:00
|
|
|
->required()
|
|
|
|
->check(CLI::ExistingPath);
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobraPublish);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobraPublish);
|
2019-09-19 21:51:11 +02:00
|
|
|
|
2019-09-23 19:25:23 +02:00
|
|
|
CLI::App* cobraMetricsPublish =
|
|
|
|
app.add_subcommand("cobra_metrics_publish", "Cobra metrics publisher");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobraMetricsPublish->fallthrough();
|
2019-11-29 00:16:39 +01:00
|
|
|
cobraMetricsPublish->add_option("--channel", channel, "Channel")->required();
|
2019-09-19 21:51:11 +02:00
|
|
|
cobraMetricsPublish->add_option("--pidfile", pidfile, "Pid file");
|
|
|
|
cobraMetricsPublish->add_option("path", path, "Path to the file to send")
|
2019-09-23 19:25:23 +02:00
|
|
|
->required()
|
|
|
|
->check(CLI::ExistingPath);
|
2019-09-19 21:51:11 +02:00
|
|
|
cobraMetricsPublish->add_flag("--stress", stress, "Stress mode");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobraMetricsPublish);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobraMetricsPublish);
|
2019-04-21 20:16:33 +02:00
|
|
|
|
2019-10-24 23:42:25 +02:00
|
|
|
CLI::App* cobra2statsd = app.add_subcommand("cobra_to_statsd", "Cobra metrics to statsd");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobra2statsd->fallthrough();
|
2019-04-09 06:52:20 +02:00
|
|
|
cobra2statsd->add_option("--host", hostname, "Statsd host");
|
|
|
|
cobra2statsd->add_option("--port", statsdPort, "Statsd port");
|
|
|
|
cobra2statsd->add_option("--prefix", prefix, "Statsd prefix");
|
|
|
|
cobra2statsd->add_option("--fields", fields, "Extract fields for naming the event")->join();
|
2020-04-15 00:30:30 +02:00
|
|
|
cobra2statsd->add_option("--gauge", gauge, "Value to extract, and use as a statsd gauge")
|
|
|
|
->join();
|
|
|
|
cobra2statsd->add_option("--timer", timer, "Value to extract, and use as a statsd timer")
|
|
|
|
->join();
|
2019-04-09 06:52:20 +02:00
|
|
|
cobra2statsd->add_option("channel", channel, "Channel")->required();
|
|
|
|
cobra2statsd->add_flag("-v", verbose, "Verbose");
|
|
|
|
cobra2statsd->add_option("--pidfile", pidfile, "Pid file");
|
2019-08-02 00:22:24 +02:00
|
|
|
cobra2statsd->add_option("--filter", filter, "Stream SQL Filter");
|
2020-03-14 00:06:13 +01:00
|
|
|
cobra2statsd->add_option("--position", position, "Stream position");
|
2020-03-23 03:36:29 +01:00
|
|
|
cobra2statsd->add_option("--queue_size",
|
|
|
|
maxQueueSize,
|
|
|
|
"Size of the queue to hold messages before they are sent to Sentry");
|
2020-04-14 04:03:53 +02:00
|
|
|
cobra2statsd->add_option("--runtime", runtime, "Runtime in seconds");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobra2statsd);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobra2statsd);
|
2019-04-09 06:52:20 +02:00
|
|
|
|
2019-10-24 23:42:25 +02:00
|
|
|
CLI::App* cobra2sentry = app.add_subcommand("cobra_to_sentry", "Cobra metrics to sentry");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobra2sentry->fallthrough();
|
2019-04-12 01:03:05 +02:00
|
|
|
cobra2sentry->add_option("--dsn", dsn, "Sentry DSN");
|
2019-12-30 17:46:18 +01:00
|
|
|
cobra2sentry->add_option("--queue_size",
|
|
|
|
maxQueueSize,
|
|
|
|
"Size of the queue to hold messages before they are sent to Sentry");
|
2019-04-12 01:03:05 +02:00
|
|
|
cobra2sentry->add_option("channel", channel, "Channel")->required();
|
|
|
|
cobra2sentry->add_flag("-v", verbose, "Verbose");
|
|
|
|
cobra2sentry->add_option("--pidfile", pidfile, "Pid file");
|
2019-08-02 00:22:24 +02:00
|
|
|
cobra2sentry->add_option("--filter", filter, "Stream SQL Filter");
|
2020-03-14 00:06:13 +01:00
|
|
|
cobra2sentry->add_option("--position", position, "Stream position");
|
2020-04-14 04:03:53 +02:00
|
|
|
cobra2sentry->add_option("--runtime", runtime, "Runtime in seconds");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobra2sentry);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobra2sentry);
|
2019-04-12 01:03:05 +02:00
|
|
|
|
2019-10-24 23:42:25 +02:00
|
|
|
CLI::App* cobra2redisApp =
|
|
|
|
app.add_subcommand("cobra_metrics_to_redis", "Cobra metrics to redis");
|
2020-04-17 18:35:47 +02:00
|
|
|
cobra2redisApp->fallthrough();
|
2019-10-24 23:42:25 +02:00
|
|
|
cobra2redisApp->add_option("channel", channel, "Channel")->required();
|
|
|
|
cobra2redisApp->add_option("--pidfile", pidfile, "Pid file");
|
|
|
|
cobra2redisApp->add_option("--filter", filter, "Stream SQL Filter");
|
2020-03-14 00:06:13 +01:00
|
|
|
cobra2redisApp->add_option("--position", position, "Stream position");
|
2019-10-24 23:42:25 +02:00
|
|
|
cobra2redisApp->add_option("--hostname", hostname, "Redis hostname");
|
|
|
|
cobra2redisApp->add_option("--port", redisPort, "Redis port");
|
|
|
|
cobra2redisApp->add_flag("-q", quiet, "Quiet / only display stats");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(cobra2redisApp);
|
2020-03-11 18:48:27 +01:00
|
|
|
addCobraConfig(cobra2redisApp);
|
2019-12-20 05:49:28 +01:00
|
|
|
|
|
|
|
CLI::App* snakeApp = app.add_subcommand("snake", "Snake server");
|
2020-04-17 18:35:47 +02:00
|
|
|
snakeApp->fallthrough();
|
2019-12-20 05:49:28 +01:00
|
|
|
snakeApp->add_option("--port", port, "Connection url");
|
|
|
|
snakeApp->add_option("--host", hostname, "Hostname");
|
|
|
|
snakeApp->add_option("--pidfile", pidfile, "Pid file");
|
|
|
|
snakeApp->add_option("--redis_hosts", redisHosts, "Redis hosts");
|
|
|
|
snakeApp->add_option("--redis_port", redisPort, "Redis hosts");
|
|
|
|
snakeApp->add_option("--redis_password", redisPassword, "Redis password");
|
|
|
|
snakeApp->add_option("--apps_config_path", appsConfigPath, "Path to auth data")
|
2019-04-23 02:24:01 +02:00
|
|
|
->check(CLI::ExistingPath);
|
2019-12-20 05:49:28 +01:00
|
|
|
snakeApp->add_flag("-v", verbose, "Verbose");
|
2020-02-01 01:55:54 +01:00
|
|
|
snakeApp->add_flag("-d", disablePong, "Disable Pongs");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(snakeApp);
|
2019-04-23 02:24:01 +02:00
|
|
|
|
2019-06-23 23:54:21 +02:00
|
|
|
CLI::App* httpServerApp = app.add_subcommand("httpd", "HTTP server");
|
2020-04-17 18:35:47 +02:00
|
|
|
httpServerApp->fallthrough();
|
2019-06-23 23:54:21 +02:00
|
|
|
httpServerApp->add_option("--port", port, "Port");
|
|
|
|
httpServerApp->add_option("--host", hostname, "Hostname");
|
2019-09-26 18:10:30 +02:00
|
|
|
httpServerApp->add_flag("-L", redirect, "Redirect all request to redirect_url");
|
|
|
|
httpServerApp->add_option("--redirect_url", redirectUrl, "Url to redirect to");
|
2019-09-30 03:29:51 +02:00
|
|
|
addTLSOptions(httpServerApp);
|
2019-06-23 23:54:21 +02:00
|
|
|
|
2019-09-01 01:46:44 +02:00
|
|
|
CLI::App* autobahnApp = app.add_subcommand("autobahn", "Test client Autobahn compliance");
|
2020-04-17 18:35:47 +02:00
|
|
|
autobahnApp->fallthrough();
|
2019-09-01 01:46:44 +02:00
|
|
|
autobahnApp->add_option("--url", url, "url");
|
2019-09-01 19:45:51 +02:00
|
|
|
autobahnApp->add_flag("-q", quiet, "Quiet");
|
2019-09-01 01:46:44 +02:00
|
|
|
|
2019-09-24 06:04:01 +02:00
|
|
|
CLI::App* redisServerApp = app.add_subcommand("redis_server", "Redis server");
|
2020-04-17 18:35:47 +02:00
|
|
|
redisServerApp->fallthrough();
|
2019-09-24 06:04:01 +02:00
|
|
|
redisServerApp->add_option("--port", port, "Port");
|
|
|
|
redisServerApp->add_option("--host", hostname, "Hostname");
|
|
|
|
|
2019-11-15 23:30:20 +01:00
|
|
|
CLI::App* proxyServerApp = app.add_subcommand("proxy_server", "Proxy server");
|
2020-04-17 18:35:47 +02:00
|
|
|
proxyServerApp->fallthrough();
|
2019-11-15 23:30:20 +01:00
|
|
|
proxyServerApp->add_option("--port", port, "Port");
|
|
|
|
proxyServerApp->add_option("--host", hostname, "Hostname");
|
|
|
|
proxyServerApp->add_option("--remote_host", remoteHost, "Remote Hostname");
|
2019-11-16 02:18:32 +01:00
|
|
|
proxyServerApp->add_flag("-v", verbose, "Verbose");
|
2019-12-20 05:49:28 +01:00
|
|
|
addTLSOptions(proxyServerApp);
|
2019-11-15 23:30:20 +01:00
|
|
|
|
2019-11-26 06:08:43 +01:00
|
|
|
CLI::App* minidumpApp = app.add_subcommand("upload_minidump", "Upload a minidump to sentry");
|
2020-04-17 18:35:47 +02:00
|
|
|
minidumpApp->fallthrough();
|
2020-02-19 06:38:28 +01:00
|
|
|
minidumpApp->add_option("--minidump", minidump, "Minidump path")
|
|
|
|
->required()
|
|
|
|
->check(CLI::ExistingPath);
|
|
|
|
minidumpApp->add_option("--metadata", metadata, "Metadata path")
|
|
|
|
->required()
|
|
|
|
->check(CLI::ExistingPath);
|
2019-11-26 06:08:43 +01:00
|
|
|
minidumpApp->add_option("--project", project, "Sentry Project")->required();
|
|
|
|
minidumpApp->add_option("--key", key, "Sentry Key")->required();
|
|
|
|
minidumpApp->add_flag("-v", verbose, "Verbose");
|
|
|
|
|
2020-01-23 06:11:48 +01:00
|
|
|
CLI::App* dnsLookupApp = app.add_subcommand("dnslookup", "DNS lookup");
|
2020-04-17 18:35:47 +02:00
|
|
|
dnsLookupApp->fallthrough();
|
2020-01-23 06:11:48 +01:00
|
|
|
dnsLookupApp->add_option("host", hostname, "Hostname")->required();
|
|
|
|
|
2019-02-22 06:24:53 +01:00
|
|
|
CLI11_PARSE(app, argc, argv);
|
|
|
|
|
2019-03-19 04:37:33 +01:00
|
|
|
// pid file handling
|
|
|
|
if (!pidfile.empty())
|
2019-02-22 06:24:53 +01:00
|
|
|
{
|
2019-03-19 04:37:33 +01:00
|
|
|
unlink(pidfile.c_str());
|
2019-03-14 21:47:03 +01:00
|
|
|
|
2019-03-19 04:37:33 +01:00
|
|
|
std::ofstream f;
|
|
|
|
f.open(pidfile);
|
|
|
|
f << getpid();
|
|
|
|
f.close();
|
|
|
|
}
|
2019-03-14 21:47:03 +01:00
|
|
|
|
2019-10-02 00:43:37 +02:00
|
|
|
if (verifyNone)
|
|
|
|
{
|
|
|
|
tlsOptions.caFile = "NONE";
|
|
|
|
}
|
|
|
|
|
2020-04-17 18:35:47 +02:00
|
|
|
if (!logfile.empty())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
auto fileLogger = spdlog::basic_logger_mt("ws", logfile);
|
|
|
|
spdlog::set_default_logger(fileLogger);
|
|
|
|
spdlog::flush_every(std::chrono::seconds(1));
|
|
|
|
|
|
|
|
std::cerr << "All logs will be redirected to " << logfile << std::endl;
|
|
|
|
}
|
2020-04-17 18:56:09 +02:00
|
|
|
catch (const spdlog::spdlog_ex& ex)
|
2020-04-17 18:35:47 +02:00
|
|
|
{
|
|
|
|
std::cerr << "Fatal error, log init failed: " << ex.what() << std::endl;
|
|
|
|
ix::uninitNetSystem();
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-11 20:40:32 +01:00
|
|
|
// Cobra config
|
|
|
|
cobraConfig.webSocketPerMessageDeflateOptions = ix::WebSocketPerMessageDeflateOptions(true);
|
|
|
|
cobraConfig.socketTLSOptions = tlsOptions;
|
|
|
|
|
2019-04-26 01:38:15 +02:00
|
|
|
int ret = 1;
|
2019-03-19 04:37:33 +01:00
|
|
|
if (app.got_subcommand("transfer"))
|
|
|
|
{
|
2019-09-30 03:29:51 +02:00
|
|
|
ret = ix::ws_transfer_main(port, hostname, tlsOptions);
|
2019-02-22 06:24:53 +01:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("send"))
|
|
|
|
{
|
2020-01-05 00:08:36 +01:00
|
|
|
ret = ix::ws_send_main(url, path, disablePerMessageDeflate, tlsOptions);
|
2019-02-22 06:24:53 +01:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("receive"))
|
|
|
|
{
|
|
|
|
bool enablePerMessageDeflate = false;
|
2019-09-30 03:29:51 +02:00
|
|
|
ret = ix::ws_receive_main(url, enablePerMessageDeflate, delayMs, tlsOptions);
|
2019-02-22 06:24:53 +01:00
|
|
|
}
|
2019-02-23 05:49:26 +01:00
|
|
|
else if (app.got_subcommand("connect"))
|
|
|
|
{
|
2019-09-23 19:25:23 +02:00
|
|
|
ret = ix::ws_connect_main(url,
|
|
|
|
headers,
|
|
|
|
disableAutomaticReconnection,
|
|
|
|
disablePerMessageDeflate,
|
|
|
|
binaryMode,
|
2019-09-30 03:29:51 +02:00
|
|
|
maxWaitBetweenReconnectionRetries,
|
2019-10-13 22:37:34 +02:00
|
|
|
tlsOptions,
|
2020-03-18 07:54:32 +01:00
|
|
|
subprotocol,
|
|
|
|
pingIntervalSecs);
|
2019-02-23 05:49:26 +01:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("chat"))
|
|
|
|
{
|
2019-04-26 01:38:15 +02:00
|
|
|
ret = ix::ws_chat_main(url, user);
|
2019-02-23 05:49:26 +01:00
|
|
|
}
|
2019-02-23 06:13:56 +01:00
|
|
|
else if (app.got_subcommand("echo_server"))
|
|
|
|
{
|
2020-02-19 06:38:28 +01:00
|
|
|
ret = ix::ws_echo_server_main(
|
2020-03-18 08:01:57 +01:00
|
|
|
port, greetings, hostname, tlsOptions, ipv6, disablePerMessageDeflate, disablePong);
|
2019-02-23 06:13:56 +01:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("broadcast_server"))
|
|
|
|
{
|
2019-09-30 03:29:51 +02:00
|
|
|
ret = ix::ws_broadcast_server_main(port, hostname, tlsOptions);
|
2019-02-23 06:13:56 +01:00
|
|
|
}
|
2019-02-23 06:47:57 +01:00
|
|
|
else if (app.got_subcommand("ping"))
|
|
|
|
{
|
2019-09-30 03:29:51 +02:00
|
|
|
ret = ix::ws_ping_pong_main(url, tlsOptions);
|
2019-02-23 06:47:57 +01:00
|
|
|
}
|
2019-03-01 06:54:03 +01:00
|
|
|
else if (app.got_subcommand("curl"))
|
2019-02-22 06:24:53 +01:00
|
|
|
{
|
2019-09-23 19:25:23 +02:00
|
|
|
ret = ix::ws_http_client_main(url,
|
|
|
|
headers,
|
|
|
|
data,
|
|
|
|
headersOnly,
|
|
|
|
connectTimeOut,
|
|
|
|
transferTimeout,
|
|
|
|
followRedirects,
|
|
|
|
maxRedirects,
|
|
|
|
verbose,
|
|
|
|
save,
|
|
|
|
output,
|
2019-09-30 03:29:51 +02:00
|
|
|
compress,
|
|
|
|
tlsOptions);
|
2019-02-22 06:24:53 +01:00
|
|
|
}
|
2019-03-20 22:29:02 +01:00
|
|
|
else if (app.got_subcommand("redis_publish"))
|
|
|
|
{
|
2019-09-23 19:25:23 +02:00
|
|
|
ret = ix::ws_redis_publish_main(hostname, redisPort, password, channel, message, count);
|
2019-03-20 22:29:02 +01:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("redis_subscribe"))
|
|
|
|
{
|
2019-04-26 01:38:15 +02:00
|
|
|
ret = ix::ws_redis_subscribe_main(hostname, redisPort, password, channel, verbose);
|
2019-03-20 22:29:02 +01:00
|
|
|
}
|
2019-04-09 06:52:20 +02:00
|
|
|
else if (app.got_subcommand("cobra_subscribe"))
|
|
|
|
{
|
2020-04-17 06:58:10 +02:00
|
|
|
bool enableHeartbeat = true;
|
|
|
|
int64_t sentCount = ix::cobra_to_stdout_bot(cobraConfig,
|
|
|
|
channel,
|
|
|
|
filter,
|
|
|
|
position,
|
|
|
|
fluentd,
|
|
|
|
quiet,
|
|
|
|
verbose,
|
|
|
|
maxQueueSize,
|
|
|
|
enableHeartbeat,
|
|
|
|
runtime);
|
|
|
|
ret = (int) sentCount;
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
2019-04-21 20:16:33 +02:00
|
|
|
else if (app.got_subcommand("cobra_publish"))
|
|
|
|
{
|
2020-03-11 23:55:45 +01:00
|
|
|
ret = ix::ws_cobra_publish_main(cobraConfig, channel, path);
|
2019-09-19 21:51:11 +02:00
|
|
|
}
|
|
|
|
else if (app.got_subcommand("cobra_metrics_publish"))
|
|
|
|
{
|
2020-03-11 23:55:45 +01:00
|
|
|
ret = ix::ws_cobra_metrics_publish_main(cobraConfig, channel, path, stress);
|
2019-04-21 20:16:33 +02:00
|
|
|
}
|
2019-04-09 06:52:20 +02:00
|
|
|
else if (app.got_subcommand("cobra_to_statsd"))
|
|
|
|
{
|
2020-03-31 01:08:47 +02:00
|
|
|
if (!timer.empty() && !gauge.empty())
|
2020-03-30 07:03:27 +02:00
|
|
|
{
|
2020-04-15 00:30:30 +02:00
|
|
|
spdlog::error("--gauge and --timer options are exclusive. "
|
2020-03-31 01:08:47 +02:00
|
|
|
"you can only supply one");
|
|
|
|
ret = 1;
|
2020-03-30 07:03:27 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-03-31 01:08:47 +02:00
|
|
|
bool enableHeartbeat = true;
|
|
|
|
ix::StatsdClient statsdClient(hostname, statsdPort, prefix);
|
|
|
|
|
|
|
|
std::string errMsg;
|
|
|
|
bool initialized = statsdClient.init(errMsg);
|
|
|
|
if (!initialized)
|
|
|
|
{
|
|
|
|
spdlog::error(errMsg);
|
|
|
|
ret = 1;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-04-17 06:58:10 +02:00
|
|
|
ret = (int) ix::cobra_to_statsd_bot(cobraConfig,
|
|
|
|
channel,
|
|
|
|
filter,
|
|
|
|
position,
|
|
|
|
statsdClient,
|
|
|
|
fields,
|
|
|
|
gauge,
|
|
|
|
timer,
|
|
|
|
verbose,
|
|
|
|
maxQueueSize,
|
|
|
|
enableHeartbeat,
|
|
|
|
runtime);
|
2020-03-31 01:08:47 +02:00
|
|
|
}
|
2020-03-30 07:03:27 +02:00
|
|
|
}
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
2019-04-12 01:03:05 +02:00
|
|
|
else if (app.got_subcommand("cobra_to_sentry"))
|
|
|
|
{
|
2020-03-12 20:13:31 +01:00
|
|
|
bool enableHeartbeat = true;
|
2020-03-12 20:30:58 +01:00
|
|
|
ix::SentryClient sentryClient(dsn);
|
2020-03-16 18:05:21 +01:00
|
|
|
sentryClient.setTLSOptions(tlsOptions);
|
2020-03-12 20:30:58 +01:00
|
|
|
|
2020-04-17 06:58:10 +02:00
|
|
|
ret = (int) ix::cobra_to_sentry_bot(cobraConfig,
|
|
|
|
channel,
|
|
|
|
filter,
|
|
|
|
position,
|
|
|
|
sentryClient,
|
|
|
|
verbose,
|
|
|
|
maxQueueSize,
|
|
|
|
enableHeartbeat,
|
|
|
|
runtime);
|
2019-04-12 01:03:05 +02:00
|
|
|
}
|
2019-10-24 23:42:25 +02:00
|
|
|
else if (app.got_subcommand("cobra_metrics_to_redis"))
|
|
|
|
{
|
2020-03-21 01:00:18 +01:00
|
|
|
ret = ix::ws_cobra_metrics_to_redis(
|
|
|
|
cobraConfig, channel, filter, position, hostname, redisPort);
|
2019-10-24 23:42:25 +02:00
|
|
|
}
|
2019-04-23 02:24:01 +02:00
|
|
|
else if (app.got_subcommand("snake"))
|
|
|
|
{
|
2019-12-30 17:46:18 +01:00
|
|
|
ret = ix::ws_snake_main(port,
|
|
|
|
hostname,
|
|
|
|
redisHosts,
|
|
|
|
redisPort,
|
|
|
|
redisPassword,
|
|
|
|
verbose,
|
|
|
|
appsConfigPath,
|
2020-02-01 01:55:54 +01:00
|
|
|
tlsOptions,
|
|
|
|
disablePong);
|
2019-04-23 02:24:01 +02:00
|
|
|
}
|
2019-06-23 23:54:21 +02:00
|
|
|
else if (app.got_subcommand("httpd"))
|
|
|
|
{
|
2019-09-30 03:29:51 +02:00
|
|
|
ret = ix::ws_httpd_main(port, hostname, redirect, redirectUrl, tlsOptions);
|
2019-06-23 23:54:21 +02:00
|
|
|
}
|
2019-09-01 01:46:44 +02:00
|
|
|
else if (app.got_subcommand("autobahn"))
|
|
|
|
{
|
2019-09-01 19:45:51 +02:00
|
|
|
ret = ix::ws_autobahn_main(url, quiet);
|
2019-09-01 01:46:44 +02:00
|
|
|
}
|
2019-09-24 06:04:01 +02:00
|
|
|
else if (app.got_subcommand("redis_server"))
|
|
|
|
{
|
|
|
|
ret = ix::ws_redis_server_main(port, hostname);
|
|
|
|
}
|
2019-11-15 23:30:20 +01:00
|
|
|
else if (app.got_subcommand("proxy_server"))
|
|
|
|
{
|
2019-11-16 02:18:32 +01:00
|
|
|
ret = ix::ws_proxy_server_main(port, hostname, tlsOptions, remoteHost, verbose);
|
2019-11-15 23:30:20 +01:00
|
|
|
}
|
2019-11-26 06:08:43 +01:00
|
|
|
else if (app.got_subcommand("upload_minidump"))
|
|
|
|
{
|
|
|
|
ret = ix::ws_sentry_minidump_upload(metadata, minidump, project, key, verbose);
|
|
|
|
}
|
2020-01-23 06:11:48 +01:00
|
|
|
else if (app.got_subcommand("dnslookup"))
|
|
|
|
{
|
|
|
|
ret = ix::ws_dns_lookup(hostname);
|
|
|
|
}
|
2019-10-01 02:31:33 +02:00
|
|
|
else if (version)
|
|
|
|
{
|
2019-12-25 06:55:34 +01:00
|
|
|
spdlog::info("ws {}", ix::userAgent());
|
2019-10-01 02:31:33 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-12-25 06:55:34 +01:00
|
|
|
spdlog::error("A subcommand or --version is required");
|
2019-10-01 02:31:33 +02:00
|
|
|
}
|
2019-02-22 06:24:53 +01:00
|
|
|
|
2019-04-26 01:38:15 +02:00
|
|
|
ix::uninitNetSystem();
|
|
|
|
return ret;
|
2019-02-22 06:24:53 +01:00
|
|
|
}
|