2023-07-26 17:58:41 +00:00
|
|
|
#include <Server/ServerType.h>
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
#include <magic_enum.hpp>
|
|
|
|
|
2023-08-10 22:55:57 +00:00
|
|
|
|
2023-07-26 17:58:41 +00:00
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
std::vector<std::string> getTypeIndexToTypeName()
|
|
|
|
{
|
|
|
|
constexpr std::size_t types_size = magic_enum::enum_count<ServerType::Type>();
|
|
|
|
|
|
|
|
std::vector<std::string> type_index_to_type_name;
|
|
|
|
type_index_to_type_name.resize(types_size);
|
|
|
|
|
|
|
|
auto entries = magic_enum::enum_entries<ServerType::Type>();
|
|
|
|
for (const auto & [entry, str] : entries)
|
|
|
|
{
|
|
|
|
auto str_copy = String(str);
|
|
|
|
std::replace(str_copy.begin(), str_copy.end(), '_', ' ');
|
|
|
|
type_index_to_type_name[static_cast<UInt64>(entry)] = std::move(str_copy);
|
|
|
|
}
|
|
|
|
|
|
|
|
return type_index_to_type_name;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const char * ServerType::serverTypeToString(ServerType::Type type)
|
|
|
|
{
|
|
|
|
/** During parsing if SystemQuery is not parsed properly it is added to Expected variants as description check IParser.h.
|
|
|
|
* Description string must be statically allocated.
|
|
|
|
*/
|
|
|
|
static std::vector<std::string> type_index_to_type_name = getTypeIndexToTypeName();
|
|
|
|
const auto & type_name = type_index_to_type_name[static_cast<UInt64>(type)];
|
|
|
|
return type_name.data();
|
|
|
|
}
|
|
|
|
|
2023-07-27 14:16:19 +00:00
|
|
|
bool ServerType::shouldStart(Type server_type, const std::string & server_custom_name) const
|
2023-07-26 17:58:41 +00:00
|
|
|
{
|
2023-08-10 16:10:33 +00:00
|
|
|
auto is_type_default = [](Type current_type)
|
2023-07-26 17:58:41 +00:00
|
|
|
{
|
2023-08-10 16:10:33 +00:00
|
|
|
switch (current_type)
|
2023-07-26 17:58:41 +00:00
|
|
|
{
|
|
|
|
case Type::TCP:
|
|
|
|
case Type::TCP_WITH_PROXY:
|
|
|
|
case Type::TCP_SECURE:
|
|
|
|
case Type::HTTP:
|
|
|
|
case Type::HTTPS:
|
|
|
|
case Type::MYSQL:
|
|
|
|
case Type::GRPC:
|
|
|
|
case Type::POSTGRESQL:
|
|
|
|
case Type::PROMETHEUS:
|
|
|
|
case Type::INTERSERVER_HTTP:
|
|
|
|
case Type::INTERSERVER_HTTPS:
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
2023-08-10 16:10:33 +00:00
|
|
|
};
|
2023-07-26 17:58:41 +00:00
|
|
|
|
2023-08-10 16:10:33 +00:00
|
|
|
if (exclude_types.contains(Type::QUERIES_ALL))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (exclude_types.contains(Type::QUERIES_DEFAULT) && is_type_default(server_type))
|
|
|
|
return false;
|
|
|
|
|
2023-08-16 23:06:42 +00:00
|
|
|
if (exclude_types.contains(Type::QUERIES_CUSTOM) && server_type == Type::CUSTOM)
|
2023-08-10 16:10:33 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
if (exclude_types.contains(server_type))
|
|
|
|
{
|
|
|
|
if (server_type != Type::CUSTOM)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (exclude_custom_names.contains(server_custom_name))
|
|
|
|
return false;
|
2023-07-26 17:58:41 +00:00
|
|
|
}
|
|
|
|
|
2023-08-10 16:10:33 +00:00
|
|
|
if (type == Type::QUERIES_ALL)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
if (type == Type::QUERIES_DEFAULT)
|
|
|
|
return is_type_default(server_type);
|
|
|
|
|
|
|
|
if (type == Type::QUERIES_CUSTOM)
|
2023-08-16 23:06:42 +00:00
|
|
|
return server_type == Type::CUSTOM;
|
2023-08-10 16:10:33 +00:00
|
|
|
|
2023-07-27 14:16:19 +00:00
|
|
|
if (type == Type::CUSTOM)
|
2023-08-10 16:10:33 +00:00
|
|
|
return server_type == type && server_custom_name == custom_name;
|
2023-07-27 14:16:19 +00:00
|
|
|
|
|
|
|
return server_type == type;
|
2023-07-26 17:58:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool ServerType::shouldStop(const std::string & port_name) const
|
|
|
|
{
|
|
|
|
Type port_type;
|
2023-08-10 16:10:33 +00:00
|
|
|
std::string port_custom_name;
|
2023-07-26 17:58:41 +00:00
|
|
|
|
|
|
|
if (port_name == "http_port")
|
|
|
|
port_type = Type::HTTP;
|
|
|
|
|
|
|
|
else if (port_name == "https_port")
|
|
|
|
port_type = Type::HTTPS;
|
|
|
|
|
|
|
|
else if (port_name == "tcp_port")
|
|
|
|
port_type = Type::TCP;
|
|
|
|
|
|
|
|
else if (port_name == "tcp_with_proxy_port")
|
|
|
|
port_type = Type::TCP_WITH_PROXY;
|
|
|
|
|
|
|
|
else if (port_name == "tcp_port_secure")
|
|
|
|
port_type = Type::TCP_SECURE;
|
|
|
|
|
|
|
|
else if (port_name == "mysql_port")
|
|
|
|
port_type = Type::MYSQL;
|
|
|
|
|
|
|
|
else if (port_name == "postgresql_port")
|
|
|
|
port_type = Type::POSTGRESQL;
|
|
|
|
|
|
|
|
else if (port_name == "grpc_port")
|
|
|
|
port_type = Type::GRPC;
|
|
|
|
|
|
|
|
else if (port_name == "prometheus.port")
|
|
|
|
port_type = Type::PROMETHEUS;
|
|
|
|
|
|
|
|
else if (port_name == "interserver_http_port")
|
|
|
|
port_type = Type::INTERSERVER_HTTP;
|
|
|
|
|
|
|
|
else if (port_name == "interserver_https_port")
|
|
|
|
port_type = Type::INTERSERVER_HTTPS;
|
|
|
|
|
|
|
|
else if (port_name.starts_with("protocols.") && port_name.ends_with(".port"))
|
2023-08-10 16:10:33 +00:00
|
|
|
{
|
2023-07-26 17:58:41 +00:00
|
|
|
port_type = Type::CUSTOM;
|
|
|
|
|
2023-08-10 16:10:33 +00:00
|
|
|
constexpr size_t protocols_size = std::string_view("protocols.").size();
|
|
|
|
constexpr size_t ports_size = std::string_view(".ports").size();
|
|
|
|
|
|
|
|
port_custom_name = port_name.substr(protocols_size, port_name.size() - protocols_size - ports_size + 1);
|
|
|
|
}
|
|
|
|
|
2023-12-14 11:47:11 +00:00
|
|
|
else if (port_name == "cloud.port")
|
|
|
|
port_type = Type::CLOUD;
|
|
|
|
|
2023-07-27 14:16:19 +00:00
|
|
|
else
|
2023-07-26 17:58:41 +00:00
|
|
|
return false;
|
|
|
|
|
2023-08-10 16:10:33 +00:00
|
|
|
return shouldStart(port_type, port_custom_name);
|
2023-07-26 17:58:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|