aboutsummaryrefslogtreecommitdiffstats
path: root/src/client
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2023-07-26 10:49:23 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2023-07-26 10:49:23 +0100
commit537a7180a0d5132c11636c4fd8b1450cd99d352c (patch)
treefb9f8c84955a411bdffbd6371ea32f2716fb3687 /src/client
parent5fd7a90fdaa33f52c59bdb0ca84451e5c1e22365 (diff)
downloadrspamd-537a7180a0d5132c11636c4fd8b1450cd99d352c.tar.gz
rspamd-537a7180a0d5132c11636c4fd8b1450cd99d352c.zip
[Rework] Use clang-format to unify formatting in all sources
No meaningful changes.
Diffstat (limited to 'src/client')
-rw-r--r--src/client/rspamc.cxx781
-rw-r--r--src/client/rspamdclient.c299
-rw-r--r--src/client/rspamdclient.h66
3 files changed, 565 insertions, 581 deletions
diff --git a/src/client/rspamc.cxx b/src/client/rspamc.cxx
index ed13f86fd..bf7a23c47 100644
--- a/src/client/rspamc.cxx
+++ b/src/client/rspamc.cxx
@@ -100,84 +100,83 @@ static gboolean rspamc_password_callback(const gchar *option_name,
static GOptionEntry entries[] =
{
- {"connect", 'h', 0, G_OPTION_ARG_STRING, &connect_str,
- "Specify host and port", nullptr},
- {"password", 'P', G_OPTION_FLAG_OPTIONAL_ARG, G_OPTION_ARG_CALLBACK,
- (void *) &rspamc_password_callback, "Specify control password", nullptr},
- {"classifier", 'c', 0, G_OPTION_ARG_STRING, &classifier,
- "Classifier to learn spam or ham", nullptr},
- {"weight", 'w', 0, G_OPTION_ARG_INT, &weight,
- "Weight for fuzzy operations", nullptr},
- {"flag", 'f', 0, G_OPTION_ARG_INT, &flag, "Flag for fuzzy operations",
- nullptr},
- {"pass-all", 'p', 0, G_OPTION_ARG_NONE, &pass_all, "Pass all filters",
- nullptr},
- {"verbose", 'v', 0, G_OPTION_ARG_NONE, &verbose, "More verbose output",
- nullptr},
- {"ip", 'i', 0, G_OPTION_ARG_STRING, &ip,
- "Emulate that message was received from specified ip address",
- nullptr},
- {"user", 'u', 0, G_OPTION_ARG_STRING, &user,
- "Emulate that message was received from specified authenticated user", nullptr},
- {"deliver", 'd', 0, G_OPTION_ARG_STRING, &deliver_to,
- "Emulate that message is delivered to specified user (for LDA/statistics)", nullptr},
- {"from", 'F', 0, G_OPTION_ARG_STRING, &from,
- "Emulate that message has specified SMTP FROM address", nullptr},
- {"rcpt", 'r', 0, G_OPTION_ARG_STRING_ARRAY, &rcpts,
- "Emulate that message has specified SMTP RCPT address", nullptr},
- {"helo", 0, 0, G_OPTION_ARG_STRING, &helo,
- "Imitate SMTP HELO passing from MTA", nullptr},
- {"hostname", 0, 0, G_OPTION_ARG_STRING, &hostname,
- "Imitate hostname passing from MTA", nullptr},
- {"timeout", 't', 0, G_OPTION_ARG_DOUBLE, &timeout,
- "Time in seconds to wait for a reply", nullptr},
- {"bind", 'b', 0, G_OPTION_ARG_STRING, &local_addr,
- "Bind to specified ip address", nullptr},
- {"commands", 0, 0, G_OPTION_ARG_NONE, &print_commands,
- "List available commands", nullptr},
- {"human", 'R', 0, G_OPTION_ARG_NONE, &humanreport, "Output human readable report", nullptr},
- {"json", 'j', 0, G_OPTION_ARG_NONE, &json, "Output json reply", nullptr},
- {"compact", '\0', 0, G_OPTION_ARG_NONE, &compact, "Output compact json reply", nullptr},
- {"headers", 0, 0, G_OPTION_ARG_NONE, &headers, "Output HTTP headers",
- nullptr},
- {"raw", 0, 0, G_OPTION_ARG_NONE, &raw, "Input is a raw file, not an email file",
- nullptr},
- {"ucl", 0, 0, G_OPTION_ARG_NONE, &ucl_reply, "Output ucl reply from rspamd",
- nullptr},
- {"max-requests", 'n', 0, G_OPTION_ARG_INT, &max_requests,
- "Maximum count of parallel requests to rspamd", nullptr},
- {"extended-urls", 0, 0, G_OPTION_ARG_NONE, &extended_urls,
- "Output urls in extended format", nullptr},
- {"key", 0, 0, G_OPTION_ARG_STRING, &pubkey,
- "Use specified pubkey to encrypt request", nullptr},
- {"exec", 'e', 0, G_OPTION_ARG_STRING, &execute,
- "Execute the specified command and pass output to it", nullptr},
- {"mime", 'm', 0, G_OPTION_ARG_NONE, &mime_output,
- "Write mime body of message with headers instead of just a scan's result", nullptr},
- {"header", 0, 0, G_OPTION_ARG_STRING_ARRAY, &http_headers,
- "Add custom HTTP header to query (can be repeated)", nullptr},
- {"exclude", 0, 0, G_OPTION_ARG_STRING_ARRAY, &exclude_patterns,
- "Exclude specific glob patterns in file names (can be repeated)", nullptr},
- {"sort", 0, 0, G_OPTION_ARG_STRING, &sort,
- "Sort output in a specific order (name, weight, frequency, hits)", nullptr},
- {"empty", 'E', 0, G_OPTION_ARG_NONE, &empty_input,
- "Allow empty input instead of reading from stdin", nullptr},
- {"fuzzy-symbol", 'S', 0, G_OPTION_ARG_STRING, &fuzzy_symbol,
- "Learn the specified fuzzy symbol", nullptr},
- {"compressed", 'z', 0, G_OPTION_ARG_NONE, &compressed,
- "Enable zstd compression", nullptr},
- {"profile", '\0', 0, G_OPTION_ARG_NONE, &profile,
- "Profile symbols execution time", nullptr},
- {"dictionary", 'D', 0, G_OPTION_ARG_FILENAME, &dictionary,
- "Use dictionary to compress data", nullptr},
- {"skip-images", '\0', 0, G_OPTION_ARG_NONE, &skip_images,
- "Skip images when learning/unlearning fuzzy", nullptr},
- {"skip-attachments", '\0', 0, G_OPTION_ARG_NONE, &skip_attachments,
- "Skip attachments when learning/unlearning fuzzy", nullptr},
- {"user-agent", 'U', 0, G_OPTION_ARG_STRING, &user_agent,
- "Use specific User-Agent instead of \"rspamc\"", nullptr},
- {nullptr, 0, 0, G_OPTION_ARG_NONE, nullptr, nullptr, nullptr}
- };
+ {"connect", 'h', 0, G_OPTION_ARG_STRING, &connect_str,
+ "Specify host and port", nullptr},
+ {"password", 'P', G_OPTION_FLAG_OPTIONAL_ARG, G_OPTION_ARG_CALLBACK,
+ (void *) &rspamc_password_callback, "Specify control password", nullptr},
+ {"classifier", 'c', 0, G_OPTION_ARG_STRING, &classifier,
+ "Classifier to learn spam or ham", nullptr},
+ {"weight", 'w', 0, G_OPTION_ARG_INT, &weight,
+ "Weight for fuzzy operations", nullptr},
+ {"flag", 'f', 0, G_OPTION_ARG_INT, &flag, "Flag for fuzzy operations",
+ nullptr},
+ {"pass-all", 'p', 0, G_OPTION_ARG_NONE, &pass_all, "Pass all filters",
+ nullptr},
+ {"verbose", 'v', 0, G_OPTION_ARG_NONE, &verbose, "More verbose output",
+ nullptr},
+ {"ip", 'i', 0, G_OPTION_ARG_STRING, &ip,
+ "Emulate that message was received from specified ip address",
+ nullptr},
+ {"user", 'u', 0, G_OPTION_ARG_STRING, &user,
+ "Emulate that message was received from specified authenticated user", nullptr},
+ {"deliver", 'd', 0, G_OPTION_ARG_STRING, &deliver_to,
+ "Emulate that message is delivered to specified user (for LDA/statistics)", nullptr},
+ {"from", 'F', 0, G_OPTION_ARG_STRING, &from,
+ "Emulate that message has specified SMTP FROM address", nullptr},
+ {"rcpt", 'r', 0, G_OPTION_ARG_STRING_ARRAY, &rcpts,
+ "Emulate that message has specified SMTP RCPT address", nullptr},
+ {"helo", 0, 0, G_OPTION_ARG_STRING, &helo,
+ "Imitate SMTP HELO passing from MTA", nullptr},
+ {"hostname", 0, 0, G_OPTION_ARG_STRING, &hostname,
+ "Imitate hostname passing from MTA", nullptr},
+ {"timeout", 't', 0, G_OPTION_ARG_DOUBLE, &timeout,
+ "Time in seconds to wait for a reply", nullptr},
+ {"bind", 'b', 0, G_OPTION_ARG_STRING, &local_addr,
+ "Bind to specified ip address", nullptr},
+ {"commands", 0, 0, G_OPTION_ARG_NONE, &print_commands,
+ "List available commands", nullptr},
+ {"human", 'R', 0, G_OPTION_ARG_NONE, &humanreport, "Output human readable report", nullptr},
+ {"json", 'j', 0, G_OPTION_ARG_NONE, &json, "Output json reply", nullptr},
+ {"compact", '\0', 0, G_OPTION_ARG_NONE, &compact, "Output compact json reply", nullptr},
+ {"headers", 0, 0, G_OPTION_ARG_NONE, &headers, "Output HTTP headers",
+ nullptr},
+ {"raw", 0, 0, G_OPTION_ARG_NONE, &raw, "Input is a raw file, not an email file",
+ nullptr},
+ {"ucl", 0, 0, G_OPTION_ARG_NONE, &ucl_reply, "Output ucl reply from rspamd",
+ nullptr},
+ {"max-requests", 'n', 0, G_OPTION_ARG_INT, &max_requests,
+ "Maximum count of parallel requests to rspamd", nullptr},
+ {"extended-urls", 0, 0, G_OPTION_ARG_NONE, &extended_urls,
+ "Output urls in extended format", nullptr},
+ {"key", 0, 0, G_OPTION_ARG_STRING, &pubkey,
+ "Use specified pubkey to encrypt request", nullptr},
+ {"exec", 'e', 0, G_OPTION_ARG_STRING, &execute,
+ "Execute the specified command and pass output to it", nullptr},
+ {"mime", 'm', 0, G_OPTION_ARG_NONE, &mime_output,
+ "Write mime body of message with headers instead of just a scan's result", nullptr},
+ {"header", 0, 0, G_OPTION_ARG_STRING_ARRAY, &http_headers,
+ "Add custom HTTP header to query (can be repeated)", nullptr},
+ {"exclude", 0, 0, G_OPTION_ARG_STRING_ARRAY, &exclude_patterns,
+ "Exclude specific glob patterns in file names (can be repeated)", nullptr},
+ {"sort", 0, 0, G_OPTION_ARG_STRING, &sort,
+ "Sort output in a specific order (name, weight, frequency, hits)", nullptr},
+ {"empty", 'E', 0, G_OPTION_ARG_NONE, &empty_input,
+ "Allow empty input instead of reading from stdin", nullptr},
+ {"fuzzy-symbol", 'S', 0, G_OPTION_ARG_STRING, &fuzzy_symbol,
+ "Learn the specified fuzzy symbol", nullptr},
+ {"compressed", 'z', 0, G_OPTION_ARG_NONE, &compressed,
+ "Enable zstd compression", nullptr},
+ {"profile", '\0', 0, G_OPTION_ARG_NONE, &profile,
+ "Profile symbols execution time", nullptr},
+ {"dictionary", 'D', 0, G_OPTION_ARG_FILENAME, &dictionary,
+ "Use dictionary to compress data", nullptr},
+ {"skip-images", '\0', 0, G_OPTION_ARG_NONE, &skip_images,
+ "Skip images when learning/unlearning fuzzy", nullptr},
+ {"skip-attachments", '\0', 0, G_OPTION_ARG_NONE, &skip_attachments,
+ "Skip attachments when learning/unlearning fuzzy", nullptr},
+ {"user-agent", 'U', 0, G_OPTION_ARG_STRING, &user_agent,
+ "Use specific User-Agent instead of \"rspamc\"", nullptr},
+ {nullptr, 0, 0, G_OPTION_ARG_NONE, nullptr, nullptr, nullptr}};
static void rspamc_symbols_output(FILE *out, ucl_object_t *obj);
@@ -225,8 +224,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = FALSE,
.is_privileged = FALSE,
.need_input = TRUE,
- .command_output_func = rspamc_symbols_output
- },
+ .command_output_func = rspamc_symbols_output},
rspamc_command{
.cmd = RSPAMC_COMMAND_LEARN_SPAM,
.name = "learn_spam",
@@ -235,8 +233,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = TRUE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_LEARN_HAM,
.name = "learn_ham",
@@ -245,41 +242,37 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = TRUE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_FUZZY_ADD,
.name = "fuzzy_add",
.path = "fuzzyadd",
.description =
- "add hashes from a message to the fuzzy storage (check -f and -w options for this command)",
+ "add hashes from a message to the fuzzy storage (check -f and -w options for this command)",
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = TRUE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_FUZZY_DEL,
.name = "fuzzy_del",
.path = "fuzzydel",
.description =
- "delete hashes from a message from the fuzzy storage (check -f option for this command)",
+ "delete hashes from a message from the fuzzy storage (check -f option for this command)",
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = TRUE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_FUZZY_DELHASH,
.name = "fuzzy_delhash",
.path = "fuzzydelhash",
.description =
- "delete a hash from fuzzy storage (check -f option for this command)",
+ "delete a hash from fuzzy storage (check -f option for this command)",
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = FALSE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_STAT,
.name = "stat",
@@ -298,8 +291,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = FALSE,
- .command_output_func = rspamc_stat_output
- },
+ .command_output_func = rspamc_stat_output},
rspamc_command{
.cmd = RSPAMC_COMMAND_COUNTERS,
.name = "counters",
@@ -308,8 +300,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = FALSE,
.need_input = FALSE,
- .command_output_func = rspamc_counters_output
- },
+ .command_output_func = rspamc_counters_output},
rspamc_command{
.cmd = RSPAMC_COMMAND_UPTIME,
.name = "uptime",
@@ -318,8 +309,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = FALSE,
.need_input = FALSE,
- .command_output_func = rspamc_uptime_output
- },
+ .command_output_func = rspamc_uptime_output},
rspamc_command{
.cmd = RSPAMC_COMMAND_ADD_SYMBOL,
.name = "add_symbol",
@@ -328,8 +318,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = FALSE,
- .command_output_func = nullptr
- },
+ .command_output_func = nullptr},
rspamc_command{
.cmd = RSPAMC_COMMAND_ADD_ACTION,
.name = "add_action",
@@ -338,9 +327,7 @@ static const constexpr auto rspamc_commands = rspamd::array_of(
.is_controller = TRUE,
.is_privileged = TRUE,
.need_input = FALSE,
- .command_output_func = nullptr
- }
-);
+ .command_output_func = nullptr});
struct rspamc_callback_data {
struct rspamc_command cmd;
@@ -348,7 +335,8 @@ struct rspamc_callback_data {
};
template<typename T>
-static constexpr auto emphasis_argument(const T &arg) -> auto {
+static constexpr auto emphasis_argument(const T &arg) -> auto
+{
if (tty) {
return fmt::format(fmt::emphasis::bold, "{}", arg);
}
@@ -357,7 +345,8 @@ static constexpr auto emphasis_argument(const T &arg) -> auto {
}
template<typename T, typename std::enable_if_t<std::is_floating_point_v<T>, bool> = false>
-static constexpr auto emphasis_argument(const T &arg, int precision) -> auto {
+static constexpr auto emphasis_argument(const T &arg, int precision) -> auto
+{
if (tty) {
return fmt::format(fmt::emphasis::bold, "{:.{}f}", arg, precision);
}
@@ -368,76 +357,77 @@ static constexpr auto emphasis_argument(const T &arg, int precision) -> auto {
using sort_lambda = std::function<int(const ucl_object_t *, const ucl_object_t *)>;
static const auto sort_map = frozen::make_unordered_map<frozen::string, sort_lambda>({
{"name", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "symbol");
- const auto *elt2 = ucl_object_lookup(o2, "symbol");
-
- if (elt1 && elt2) {
- return strcmp(ucl_object_tostring(elt1),
- ucl_object_tostring(elt2));
- }
- else if (ucl_object_key(o1) != nullptr && ucl_object_key(o2) != nullptr) {
- return strcmp(ucl_object_key(o1),
- ucl_object_key(o2));
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "symbol");
+ const auto *elt2 = ucl_object_lookup(o2, "symbol");
+
+ if (elt1 && elt2) {
+ return strcmp(ucl_object_tostring(elt1),
+ ucl_object_tostring(elt2));
+ }
+ else if (ucl_object_key(o1) != nullptr && ucl_object_key(o2) != nullptr) {
+ return strcmp(ucl_object_key(o1),
+ ucl_object_key(o2));
+ }
+ return 0;
+ }},
{"weight", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "weight");
- const auto *elt2 = ucl_object_lookup(o2, "weight");
-
- if (elt1 && elt2) {
- return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "weight");
+ const auto *elt2 = ucl_object_lookup(o2, "weight");
+
+ if (elt1 && elt2) {
+ return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
+ }
+ return 0;
+ }},
{"score", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "score");
- const auto *elt2 = ucl_object_lookup(o2, "score");
-
- if (elt1 && elt2) {
- return std::fabs(ucl_object_todouble(elt2)) * 1000.0 -
- std::fabs(ucl_object_todouble(elt1)) * 1000.0;
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "score");
+ const auto *elt2 = ucl_object_lookup(o2, "score");
+
+ if (elt1 && elt2) {
+ return std::fabs(ucl_object_todouble(elt2)) * 1000.0 -
+ std::fabs(ucl_object_todouble(elt1)) * 1000.0;
+ }
+ return 0;
+ }},
{"time", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "time");
- const auto *elt2 = ucl_object_lookup(o2, "time");
-
- if (elt1 && elt2) {
- return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "time");
+ const auto *elt2 = ucl_object_lookup(o2, "time");
+
+ if (elt1 && elt2) {
+ return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
+ }
+ return 0;
+ }},
{"frequency", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "frequency");
- const auto *elt2 = ucl_object_lookup(o2, "frequency");
-
- if (elt1 && elt2) {
- return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "frequency");
+ const auto *elt2 = ucl_object_lookup(o2, "frequency");
+
+ if (elt1 && elt2) {
+ return ucl_object_todouble(elt2) * 1000.0 - ucl_object_todouble(elt1) * 1000.0;
+ }
+ return 0;
+ }},
{"hits", [](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- const auto *elt1 = ucl_object_lookup(o1, "hits");
- const auto *elt2 = ucl_object_lookup(o2, "hits");
-
- if (elt1 && elt2) {
- return ucl_object_toint(elt2) - ucl_object_toint(elt1);
- }
- return 0;
- }},
+ const auto *elt1 = ucl_object_lookup(o1, "hits");
+ const auto *elt2 = ucl_object_lookup(o2, "hits");
+
+ if (elt1 && elt2) {
+ return ucl_object_toint(elt2) - ucl_object_toint(elt1);
+ }
+ return 0;
+ }},
});
/* TODO: remove once migrate to C++20 standard */
static constexpr auto
-sv_ends_with(std::string_view inp, std::string_view suffix) -> bool {
+sv_ends_with(std::string_view inp, std::string_view suffix) -> bool
+{
return inp.size() >= suffix.size() && inp.compare(inp.size() - suffix.size(), std::string_view::npos, suffix) == 0;
}
template<typename T>
auto sort_ucl_container_with_default(T &cont, const char *default_sort,
- typename std::enable_if<std::is_same_v<typename T::value_type, const ucl_object_t *>>::type* = 0) -> void
+ typename std::enable_if<std::is_same_v<typename T::value_type, const ucl_object_t *>>::type * = 0) -> void
{
auto real_sort = sort ? sort : default_sort;
if (real_sort) {
@@ -452,11 +442,11 @@ auto sort_ucl_container_with_default(T &cont, const char *default_sort,
const auto sort_functor = sort_map.find(sort_view);
if (sort_functor != sort_map.end()) {
std::stable_sort(std::begin(cont), std::end(cont),
- [&](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
- auto order = sort_functor->second(o1, o2);
+ [&](const ucl_object_t *o1, const ucl_object_t *o2) -> int {
+ auto order = sort_functor->second(o1, o2);
- return inverse ? order > 0 : order < 0;
- });
+ return inverse ? order > 0 : order < 0;
+ });
}
}
}
@@ -533,7 +523,7 @@ read_cmd_line(gint *argc, gchar ***argv)
/* Prepare parser */
context = g_option_context_new("- run rspamc client");
g_option_context_set_summary(context,
- "Summary:\n Rspamd client version " RVERSION "\n Release id: " RID);
+ "Summary:\n Rspamd client version " RVERSION "\n Release id: " RID);
g_option_context_add_main_entries(context, entries, nullptr);
/* Parse options */
@@ -577,7 +567,7 @@ rspamd_string_tolower(const char *inp) -> std::string
{
std::string s{inp};
std::transform(std::begin(s), std::end(s), std::begin(s),
- [](unsigned char c) { return std::tolower(c); });
+ [](unsigned char c) { return std::tolower(c); });
return s;
}
@@ -585,16 +575,16 @@ static auto
rspamd_action_from_str_rspamc(const char *data) -> std::optional<int>
{
static constexpr const auto str_map = frozen::make_unordered_map<frozen::string, int>({
- {"reject", METRIC_ACTION_REJECT},
- {"greylist", METRIC_ACTION_GREYLIST},
- {"add_header", METRIC_ACTION_ADD_HEADER},
- {"add header", METRIC_ACTION_ADD_HEADER},
+ {"reject", METRIC_ACTION_REJECT},
+ {"greylist", METRIC_ACTION_GREYLIST},
+ {"add_header", METRIC_ACTION_ADD_HEADER},
+ {"add header", METRIC_ACTION_ADD_HEADER},
{"rewrite_subject", METRIC_ACTION_REWRITE_SUBJECT},
{"rewrite subject", METRIC_ACTION_REWRITE_SUBJECT},
- {"soft_reject", METRIC_ACTION_SOFT_REJECT},
- {"soft reject", METRIC_ACTION_SOFT_REJECT},
- {"no_action", METRIC_ACTION_NOACTION},
- {"no action", METRIC_ACTION_NOACTION},
+ {"soft_reject", METRIC_ACTION_SOFT_REJECT},
+ {"soft reject", METRIC_ACTION_SOFT_REJECT},
+ {"no_action", METRIC_ACTION_NOACTION},
+ {"no action", METRIC_ACTION_NOACTION},
});
auto st_lower = rspamd_string_tolower(data);
@@ -608,18 +598,18 @@ static auto
check_rspamc_command(const char *cmd) -> std::optional<rspamc_command>
{
static constexpr const auto str_map = frozen::make_unordered_map<frozen::string, int>({
- {"symbols", RSPAMC_COMMAND_SYMBOLS},
- {"check", RSPAMC_COMMAND_SYMBOLS},
- {"report", RSPAMC_COMMAND_SYMBOLS},
- {"learn_spam", RSPAMC_COMMAND_LEARN_SPAM},
- {"learn_ham", RSPAMC_COMMAND_LEARN_HAM},
- {"fuzzy_add", RSPAMC_COMMAND_FUZZY_ADD},
- {"fuzzy_del", RSPAMC_COMMAND_FUZZY_DEL},
+ {"symbols", RSPAMC_COMMAND_SYMBOLS},
+ {"check", RSPAMC_COMMAND_SYMBOLS},
+ {"report", RSPAMC_COMMAND_SYMBOLS},
+ {"learn_spam", RSPAMC_COMMAND_LEARN_SPAM},
+ {"learn_ham", RSPAMC_COMMAND_LEARN_HAM},
+ {"fuzzy_add", RSPAMC_COMMAND_FUZZY_ADD},
+ {"fuzzy_del", RSPAMC_COMMAND_FUZZY_DEL},
{"fuzzy_delhash", RSPAMC_COMMAND_FUZZY_DELHASH},
- {"stat", RSPAMC_COMMAND_STAT},
- {"stat_reset", RSPAMC_COMMAND_STAT_RESET},
- {"counters", RSPAMC_COMMAND_COUNTERS},
- {"uptime", RSPAMC_COMMAND_UPTIME},
+ {"stat", RSPAMC_COMMAND_STAT},
+ {"stat_reset", RSPAMC_COMMAND_STAT_RESET},
+ {"counters", RSPAMC_COMMAND_COUNTERS},
+ {"uptime", RSPAMC_COMMAND_UPTIME},
});
std::string cmd_lc = rspamd_string_tolower(cmd);
@@ -653,18 +643,18 @@ print_commands_list()
for (const auto &cmd: rspamc_commands) {
fmt::print(stdout,
- " {:>{}} ({:7}{:1})\t{}\n",
- cmd.name,
- cmd_len,
- cmd.is_controller ? "control" : "normal",
- cmd.is_privileged ? "*" : "",
- cmd.description);
+ " {:>{}} ({:7}{:1})\t{}\n",
+ cmd.name,
+ cmd_len,
+ cmd.is_controller ? "control" : "normal",
+ cmd.is_privileged ? "*" : "",
+ cmd.description);
}
fmt::print(stdout,
- "\n* is for privileged commands that may need password (see -P option)\n");
+ "\n* is for privileged commands that may need password (see -P option)\n");
fmt::print(stdout,
- "control commands use port 11334 while normal use 11333 by default (see -h option)\n");
+ "control commands use port 11334 while normal use 11333 by default (see -h option)\n");
}
static void
@@ -676,7 +666,7 @@ add_options(GQueue *opts)
rspamd_inet_addr_t *addr = nullptr;
if (!rspamd_parse_inet_address(&addr, ip, strlen(ip),
- RSPAMD_INET_ADDRESS_PARSE_DEFAULT)) {
+ RSPAMD_INET_ADDRESS_PARSE_DEFAULT)) {
/* Try to resolve */
struct addrinfo hints, *res, *cur;
int r;
@@ -684,7 +674,7 @@ add_options(GQueue *opts)
memset(&hints, 0, sizeof(hints));
hints.ai_socktype = SOCK_STREAM; /* Type of the socket */
#ifdef AI_IDN
- hints.ai_flags = AI_NUMERICSERV|AI_IDN;
+ hints.ai_flags = AI_NUMERICSERV | AI_IDN;
#else
hints.ai_flags = AI_NUMERICSERV;
#endif
@@ -695,7 +685,7 @@ add_options(GQueue *opts)
cur = res;
while (cur) {
addr = rspamd_inet_address_from_sa(cur->ai_addr,
- cur->ai_addrlen);
+ cur->ai_addrlen);
if (addr != nullptr) {
ip = g_strdup(rspamd_inet_address_to_string(addr));
@@ -710,8 +700,8 @@ add_options(GQueue *opts)
}
else {
fmt::print(stderr, "address resolution for {} failed: {}\n",
- ip,
- gai_strerror(r));
+ ip,
+ gai_strerror(r));
}
}
else {
@@ -809,8 +799,8 @@ add_options(GQueue *opts)
}
else {
add_client_header(opts,
- hdr_view.substr(0, std::distance(std::begin(hdr_view), delim_pos)),
- hdr_view.substr(std::distance(std::begin(hdr_view), delim_pos) + 1));
+ hdr_view.substr(0, std::distance(std::begin(hdr_view), delim_pos)),
+ hdr_view.substr(std::distance(std::begin(hdr_view), delim_pos) + 1));
}
hdr++;
@@ -837,12 +827,12 @@ rspamc_print_indented_line(FILE *out, std::string_view line) -> void
constexpr const auto break_begin = " \f\n\r\t\v?,;<({[~!#$%^&*+:=/\\|"sv;
constexpr const auto break_end = " \f\n\r\t\v?,;]})>~!#$%^&*+:_=/\\|"sv;
- for (size_t pos = 0; pos < line.size(); ) {
- auto len = pos ? (maxlen-indent) : maxlen;
+ for (size_t pos = 0; pos < line.size();) {
+ auto len = pos ? (maxlen - indent) : maxlen;
auto s = line.substr(pos, len);
- if ((pos + s.size()) < line.size() && // reached EOL?
- break_begin.find_first_of( line.at(pos + s.size())) == std::string_view::npos // new word next?
- ) {
+ if ((pos + s.size()) < line.size() && // reached EOL?
+ break_begin.find_first_of(line.at(pos + s.size())) == std::string_view::npos// new word next?
+ ) {
auto wrap_at = s.find_last_of(break_end);
if (wrap_at != std::string_view::npos) {
s = line.substr(pos, wrap_at + 1);
@@ -852,7 +842,7 @@ rspamc_print_indented_line(FILE *out, std::string_view line) -> void
fmt::print(out, "{:>{}}", " ", indent);
}
fmt::print(out, "{}\n", s);
- pos = line.find_first_not_of(whitespace, pos + s.size()); //skip leading whitespace
+ pos = line.find_first_not_of(whitespace, pos + s.size());//skip leading whitespace
}
}
@@ -886,7 +876,7 @@ rspamc_symbol_human_output(FILE *out, const ucl_object_t *obj)
line += fmt::format("{}[", desc == nullptr ? "" : " ");
- while ((cur = ucl_object_iterate (val, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(val, &it, true)) != nullptr) {
if (first) {
line += fmt::format("{}", ucl_object_tostring(cur));
first = false;
@@ -919,7 +909,7 @@ rspamc_symbol_output(FILE *out, const ucl_object_t *obj)
fmt::print(out, "[");
- while ((cur = ucl_object_iterate (val, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(val, &it, true)) != nullptr) {
if (first) {
fmt::print(out, "{}", ucl_object_tostring(cur));
first = false;
@@ -938,7 +928,7 @@ rspamc_metric_output(FILE *out, const ucl_object_t *obj)
{
int got_scores = 0;
bool is_spam = false;
- double score = 0, required_score = 0, greylist_score =0, addheader_score = 0;
+ double score = 0, required_score = 0, greylist_score = 0, addheader_score = 0;
auto print_protocol_string = [&](const char *ucl_name, const char *output_message) {
auto *elt = ucl_object_lookup(obj, ucl_name);
@@ -990,11 +980,11 @@ rspamc_metric_output(FILE *out, const ucl_object_t *obj)
if (humanreport) {
fmt::print(out,
- "{}/{}/{}/{}",
- emphasis_argument(score, 2),
- emphasis_argument(greylist_score, 2),
- emphasis_argument(addheader_score, 2),
- emphasis_argument(required_score, 2));
+ "{}/{}/{}/{}",
+ emphasis_argument(score, 2),
+ emphasis_argument(greylist_score, 2),
+ emphasis_argument(addheader_score, 2),
+ emphasis_argument(required_score, 2));
}
elt = ucl_object_lookup(obj, "action");
@@ -1043,7 +1033,7 @@ rspamc_metric_output(FILE *out, const ucl_object_t *obj)
is_spam = act.value() < METRIC_ACTION_GREYLIST ? true : false;
if (!humanreport) {
- fmt::print(out, "Spam: {}\n", is_spam ? "true" : "false");
+ fmt::print(out, "Spam: {}\n", is_spam ? "true" : "false");
}
}
else {
@@ -1072,15 +1062,15 @@ rspamc_metric_output(FILE *out, const ucl_object_t *obj)
}
else if (got_scores == 2) {
fmt::print(out,
- "Score: {} / {}\n",
- emphasis_argument(score, 2),
- emphasis_argument(required_score, 2));
+ "Score: {} / {}\n",
+ emphasis_argument(score, 2),
+ emphasis_argument(required_score, 2));
}
if (humanreport) {
fmt::print(out, "Content analysis details: ({} points, {} required)\n\n",
- emphasis_argument(score, 2),
- emphasis_argument(addheader_score, 2));
+ emphasis_argument(score, 2),
+ emphasis_argument(addheader_score, 2));
fmt::print(out, " pts rule name description\n");
fmt::print(out, "---- ---------------------- --------------------------------------------------\n");
}
@@ -1092,13 +1082,13 @@ rspamc_metric_output(FILE *out, const ucl_object_t *obj)
ucl_object_iter_t it = nullptr;
const ucl_object_t *cur;
- while ((cur = ucl_object_iterate (elt, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(elt, &it, true)) != nullptr) {
symbols.push_back(cur);
}
sort_ucl_container_with_default(symbols, "name");
- for (const auto *sym_obj : symbols) {
+ for (const auto *sym_obj: symbols) {
humanreport ? rspamc_symbol_human_output(out, sym_obj) : rspamc_symbol_output(out, sym_obj);
}
}
@@ -1115,17 +1105,17 @@ rspamc_profile_output(FILE *out, const ucl_object_t *obj)
std::vector<const ucl_object_t *> ar;
- while ((cur = ucl_object_iterate (obj, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(obj, &it, true)) != nullptr) {
ar.push_back(cur);
}
std::stable_sort(std::begin(ar), std::end(ar),
- [](const ucl_object_t *u1, const ucl_object_t *u2) -> int {
- return ucl_object_compare(u1, u2);
- });
+ [](const ucl_object_t *u1, const ucl_object_t *u2) -> int {
+ return ucl_object_compare(u1, u2);
+ });
- for (const auto *cur_elt : ar) {
+ for (const auto *cur_elt: ar) {
fmt::print(out, "\t{}: {:3} usec\n",
- ucl_object_key(cur_elt), ucl_object_todouble(cur_elt));
+ ucl_object_key(cur_elt), ucl_object_todouble(cur_elt));
}
}
@@ -1152,10 +1142,10 @@ rspamc_symbols_output(FILE *out, ucl_object_t *obj)
char *emitted;
if (!extended_urls || compact) {
- emitted = (char *)ucl_object_emit(elt, UCL_EMIT_JSON_COMPACT);
+ emitted = (char *) ucl_object_emit(elt, UCL_EMIT_JSON_COMPACT);
}
else {
- emitted = (char *)ucl_object_emit(elt, UCL_EMIT_JSON);
+ emitted = (char *) ucl_object_emit(elt, UCL_EMIT_JSON);
}
if (humanreport) {
@@ -1174,10 +1164,10 @@ rspamc_symbols_output(FILE *out, ucl_object_t *obj)
if (elt) {
char *emitted;
if (!extended_urls || compact) {
- emitted = (char *)ucl_object_emit(elt, UCL_EMIT_JSON_COMPACT);
+ emitted = (char *) ucl_object_emit(elt, UCL_EMIT_JSON_COMPACT);
}
else {
- emitted = (char *)ucl_object_emit(elt, UCL_EMIT_JSON);
+ emitted = (char *) ucl_object_emit(elt, UCL_EMIT_JSON);
}
if (humanreport) {
@@ -1201,15 +1191,16 @@ rspamc_symbols_output(FILE *out, ucl_object_t *obj)
ucl_object_iter_t mit = nullptr;
const ucl_object_t *cmesg;
- while ((cmesg = ucl_object_iterate (elt, &mit, true)) != nullptr) {
+ while ((cmesg = ucl_object_iterate(elt, &mit, true)) != nullptr) {
if (ucl_object_type(cmesg) == UCL_STRING) {
fmt::print(out, "Message - {}: {}\n",
- ucl_object_key(cmesg), ucl_object_tostring(cmesg));
- } else {
+ ucl_object_key(cmesg), ucl_object_tostring(cmesg));
+ }
+ else {
char *rendered_message;
- rendered_message = (char *)ucl_object_emit(cmesg, UCL_EMIT_JSON_COMPACT);
+ rendered_message = (char *) ucl_object_emit(cmesg, UCL_EMIT_JSON_COMPACT);
fmt::print(out, "Message - {}: {:.60}\n",
- ucl_object_key(cmesg), rendered_message);
+ ucl_object_key(cmesg), rendered_message);
free(rendered_message);
}
}
@@ -1223,7 +1214,7 @@ rspamc_symbols_output(FILE *out, ucl_object_t *obj)
ucl_object_iter_t it = nullptr;
const ucl_object_t *cur;
- while ((cur = ucl_object_iterate (elt, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(elt, &it, true)) != nullptr) {
fmt::print(out, "DKIM-Signature: {}\n", ucl_object_tostring(cur));
}
}
@@ -1243,8 +1234,7 @@ rspamc_uptime_output(FILE *out, ucl_object_t *obj)
const auto *elt = ucl_object_lookup(obj, "version");
if (elt != nullptr) {
- fmt::print(out, "Rspamd version: {}\n", ucl_object_tostring(
- elt));
+ fmt::print(out, "Rspamd version: {}\n", ucl_object_tostring(elt));
}
elt = ucl_object_lookup(obj, "uptime");
@@ -1256,22 +1246,22 @@ rspamc_uptime_output(FILE *out, ucl_object_t *obj)
hours = seconds / 3600 - days * 24;
minutes = seconds / 60 - hours * 60 - days * 1440;
fmt::print("{} day{} {} hour{} {} minute{}\n", days,
- days > 1 ? "s" : "", hours, hours > 1 ? "s" : "",
- minutes, minutes > 1 ? "s" : "");
+ days > 1 ? "s" : "", hours, hours > 1 ? "s" : "",
+ minutes, minutes > 1 ? "s" : "");
}
- /* If uptime is less than 1 minute print only seconds */
+ /* If uptime is less than 1 minute print only seconds */
else if (seconds / 60 == 0) {
fmt::print("{} second{}\n", seconds,
- seconds > 1 ? "s" : "");
+ seconds > 1 ? "s" : "");
}
- /* Else print the minutes and seconds. */
+ /* Else print the minutes and seconds. */
else {
hours = seconds / 3600;
minutes = seconds / 60 - hours * 60;
seconds -= hours * 3600 + minutes * 60;
fmt::print("{} hour {} minute{} {} second{}\n", hours,
- minutes, minutes > 1 ? "s" : "",
- seconds, seconds > 1 ? "s" : "");
+ minutes, minutes > 1 ? "s" : "",
+ seconds, seconds > 1 ? "s" : "");
}
}
}
@@ -1291,7 +1281,7 @@ rspamc_counters_output(FILE *out, ucl_object_t *obj)
ucl_object_iter_t iter = nullptr;
const ucl_object_t *cur;
- while ((cur = ucl_object_iterate (obj, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(obj, &iter, true)) != nullptr) {
const auto *sym = ucl_object_lookup(cur, "symbol");
if (sym != nullptr) {
if (sym->len > max_len) {
@@ -1307,7 +1297,7 @@ rspamc_counters_output(FILE *out, ucl_object_t *obj)
char dash_buf[82], sym_buf[82];
const int dashes = 44;
- max_len = MIN (sizeof(dash_buf) - dashes - 1, max_len);
+ max_len = MIN(sizeof(dash_buf) - dashes - 1, max_len);
memset(dash_buf, '-', dashes + max_len);
dash_buf[dashes + max_len] = '\0';
@@ -1315,19 +1305,19 @@ rspamc_counters_output(FILE *out, ucl_object_t *obj)
fmt::print(out, " {} \n", emphasis_argument(dash_buf));
fmt::print(out,
- "| {:<4} | {:<{}} | {:^7} | {:^13} | {:^7} |\n",
- "Pri",
- "Symbol",
- max_len,
- "Weight",
- "Frequency",
- "Hits");
+ "| {:<4} | {:<{}} | {:^7} | {:^13} | {:^7} |\n",
+ "Pri",
+ "Symbol",
+ max_len,
+ "Weight",
+ "Frequency",
+ "Hits");
fmt::print(out, " {} \n", emphasis_argument(dash_buf));
fmt::print(out, "| {:<4} | {:<{}} | {:^7} | {:^13} | {:^7} |\n", "",
- "", max_len,
- "", "hits/min", "");
+ "", max_len,
+ "", "hits/min", "");
- for (const auto [i, cur] : rspamd::enumerate(counters_vec)) {
+ for (const auto [i, cur]: rspamd::enumerate(counters_vec)) {
fmt::print(out, " {} \n", dash_buf);
const auto *sym = ucl_object_lookup(cur, "symbol");
const auto *weight = ucl_object_lookup(cur, "weight");
@@ -1340,7 +1330,7 @@ rspamc_counters_output(FILE *out, ucl_object_t *obj)
if (sym->len > max_len) {
rspamd_snprintf(sym_buf, sizeof(sym_buf), "%*s...",
- (max_len - 3), ucl_object_tostring(sym));
+ (max_len - 3), ucl_object_tostring(sym));
sym_name = sym_buf;
}
else {
@@ -1348,12 +1338,12 @@ rspamc_counters_output(FILE *out, ucl_object_t *obj)
}
fmt::print(out, "| {:<4} | {:<{}} | {:^7.1f} | {:^6.3f}({:^5.3f}) | {:^7} |\n", i,
- sym_name,
- max_len,
- ucl_object_todouble(weight),
- ucl_object_todouble(freq) * 60.0,
- ucl_object_todouble(freq_dev) * 60.0,
- (std::uintmax_t)ucl_object_toint(nhits));
+ sym_name,
+ max_len,
+ ucl_object_todouble(weight),
+ ucl_object_todouble(freq) * 60.0,
+ ucl_object_todouble(freq_dev) * 60.0,
+ (std::uintmax_t) ucl_object_toint(nhits));
}
}
fmt::print(out, " {} \n", dash_buf);
@@ -1367,22 +1357,22 @@ rspamc_stat_actions(ucl_object_t *obj, std::string &out, std::int64_t scanned)
if (scanned > 0) {
if (actions && ucl_object_type(actions) == UCL_OBJECT) {
- while ((cur = ucl_object_iterate (actions, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(actions, &iter, true)) != nullptr) {
auto cnt = ucl_object_toint(cur);
fmt::format_to(std::back_inserter(out), "Messages with action {}: {}, {:.2f}%\n",
- ucl_object_key(cur), emphasis_argument(cnt),
- ((double) cnt / (double) scanned) * 100.);
+ ucl_object_key(cur), emphasis_argument(cnt),
+ ((double) cnt / (double) scanned) * 100.);
}
}
auto spam = ucl_object_toint(ucl_object_lookup(obj, "spam_count"));
auto ham = ucl_object_toint(ucl_object_lookup(obj, "ham_count"));
fmt::format_to(std::back_inserter(out), "Messages treated as spam: {}, {:.2f}%\n",
- emphasis_argument(spam),
- ((double) spam / (double) scanned) * 100.);
+ emphasis_argument(spam),
+ ((double) spam / (double) scanned) * 100.);
fmt::format_to(std::back_inserter(out), "Messages treated as ham: {}, {:.2f}%\n",
- emphasis_argument(ham),
- ((double) ham / (double) scanned) * 100.);
+ emphasis_argument(ham),
+ ((double) ham / (double) scanned) * 100.);
}
}
@@ -1401,18 +1391,18 @@ rspamc_stat_statfile(const ucl_object_t *obj, std::string &out)
if (label) {
fmt::format_to(std::back_inserter(out), "Statfile: {} <{}> type: {}; ", symbol,
- label, type);
+ label, type);
}
else {
fmt::format_to(std::back_inserter(out), "Statfile: {} type: {}; ", symbol, type);
}
fmt::format_to(std::back_inserter(out), "length: {}; free blocks: {}; total blocks: {}; "
"free: {:.2f}%; learned: {}; users: {}; languages: {}\n",
- size,
- blocks - used_blocks, blocks,
- blocks > 0 ? (blocks - used_blocks) * 100.0 / (double) blocks : 0,
- version,
- nusers, nlanguages);
+ size,
+ blocks - used_blocks, blocks,
+ blocks > 0 ? (blocks - used_blocks) * 100.0 / (double) blocks : 0,
+ version,
+ nusers, nlanguages);
}
static void
@@ -1424,16 +1414,16 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
auto scanned = ucl_object_toint(ucl_object_lookup(obj, "scanned"));
fmt::format_to(std::back_inserter(out_str), "Messages scanned: {}\n",
- emphasis_argument(scanned));
+ emphasis_argument(scanned));
rspamc_stat_actions(obj, out_str, scanned);
fmt::format_to(std::back_inserter(out_str), "Messages learned: {}\n",
- emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "learned"))));
+ emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "learned"))));
fmt::format_to(std::back_inserter(out_str), "Connections count: {}\n",
- emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "connections"))));
+ emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "connections"))));
fmt::format_to(std::back_inserter(out_str), "Control connections count: {}\n",
- emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "control_connections"))));
+ emphasis_argument(ucl_object_toint(ucl_object_lookup(obj, "control_connections"))));
const auto *avg_time_obj = ucl_object_lookup(obj, "scan_times");
@@ -1442,7 +1432,7 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
const ucl_object_t *cur;
std::vector<float> nums;
- while ((cur = ucl_object_iterate (avg_time_obj, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(avg_time_obj, &iter, true)) != nullptr) {
if (ucl_object_type(cur) == UCL_FLOAT || ucl_object_type(cur) == UCL_INT) {
nums.push_back(ucl_object_todouble(cur));
}
@@ -1453,26 +1443,26 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
if (cnt > 0) {
auto sum = rspamd_sum_floats(nums.data(), &cnt);
fmt::format_to(std::back_inserter(out_str),
- "Average scan time: {} sec\n",
- emphasis_argument(sum / cnt, 3));
+ "Average scan time: {} sec\n",
+ emphasis_argument(sum / cnt, 3));
}
}
/* Pools */
- fmt::format_to(std::back_inserter(out_str), "Pools allocated: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "pools_allocated")));
- fmt::format_to(std::back_inserter(out_str), "Pools freed: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "pools_freed")));
- fmt::format_to(std::back_inserter(out_str), "Bytes allocated: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "bytes_allocated")));
- fmt::format_to(std::back_inserter(out_str), "Memory chunks allocated: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "chunks_allocated")));
- fmt::format_to(std::back_inserter(out_str), "Shared chunks allocated: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "shared_chunks_allocated")));
- fmt::format_to(std::back_inserter(out_str), "Chunks freed: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "chunks_freed")));
- fmt::format_to(std::back_inserter(out_str), "Oversized chunks: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "chunks_oversized")));
+ fmt::format_to(std::back_inserter(out_str), "Pools allocated: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "pools_allocated")));
+ fmt::format_to(std::back_inserter(out_str), "Pools freed: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "pools_freed")));
+ fmt::format_to(std::back_inserter(out_str), "Bytes allocated: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "bytes_allocated")));
+ fmt::format_to(std::back_inserter(out_str), "Memory chunks allocated: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "chunks_allocated")));
+ fmt::format_to(std::back_inserter(out_str), "Shared chunks allocated: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "shared_chunks_allocated")));
+ fmt::format_to(std::back_inserter(out_str), "Chunks freed: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "chunks_freed")));
+ fmt::format_to(std::back_inserter(out_str), "Oversized chunks: {}\n",
+ ucl_object_toint(ucl_object_lookup(obj, "chunks_oversized")));
/* Fuzzy */
const auto *st = ucl_object_lookup(obj, "fuzzy_hashes");
@@ -1481,16 +1471,16 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
const ucl_object_t *cur;
std::uint64_t stored = 0;
- while ((cur = ucl_iterate_object (st, &it, true)) != nullptr) {
+ while ((cur = ucl_iterate_object(st, &it, true)) != nullptr) {
auto num = ucl_object_toint(cur);
fmt::format_to(std::back_inserter(out_str), "Fuzzy hashes in storage \"{}\": {}\n",
- ucl_object_key(cur),
- num);
+ ucl_object_key(cur),
+ num);
stored += num;
}
fmt::format_to(std::back_inserter(out_str), "Fuzzy hashes stored: {}\n",
- stored);
+ stored);
}
st = ucl_object_lookup(obj, "fuzzy_checked");
@@ -1500,7 +1490,7 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
out_str += "Fuzzy hashes checked: ";
- while ((cur = ucl_object_iterate (st, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(st, &iter, true)) != nullptr) {
fmt::format_to(std::back_inserter(out_str), "{} ", ucl_object_toint(cur));
}
@@ -1514,7 +1504,7 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
out_str += "Fuzzy hashes found: ";
- while ((cur = ucl_object_iterate (st, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(st, &iter, true)) != nullptr) {
fmt::format_to(std::back_inserter(out_str), "{} ", ucl_object_toint(cur));
}
@@ -1526,12 +1516,12 @@ rspamc_stat_output(FILE *out, ucl_object_t *obj)
ucl_object_iter_t iter = nullptr;
const ucl_object_t *cur;
- while ((cur = ucl_object_iterate (st, &iter, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(st, &iter, true)) != nullptr) {
rspamc_stat_statfile(cur, out_str);
}
}
fmt::format_to(std::back_inserter(out_str), "Total learns: {}\n",
- ucl_object_toint(ucl_object_lookup(obj, "total_learns")));
+ ucl_object_toint(ucl_object_lookup(obj, "total_learns")));
fmt::print(out, "{}", out_str.c_str());
}
@@ -1541,9 +1531,9 @@ rspamc_output_headers(FILE *out, struct rspamd_http_message *msg)
{
struct rspamd_http_header *h;
- kh_foreach_value (msg->headers, h, {
+ kh_foreach_value(msg->headers, h, {
fmt::print(out, "{}: {}\n", std::string_view{h->name.begin, h->name.len},
- std::string_view{h->value.begin, h->value.len});
+ std::string_view{h->value.begin, h->value.len});
});
fmt::print(out, "\n");
@@ -1608,9 +1598,9 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
}
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Scanner: {}{}",
- "rspamc " RVERSION, line_end);
+ "rspamc " RVERSION, line_end);
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Scan-Time: {:.3}{}",
- time, line_end);
+ time, line_end);
/*
* TODO: add milter_headers support here
@@ -1619,21 +1609,21 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
fmt::format_to(std::back_inserter(added_headers), "X-Spam: yes{}", line_end);
}
- fmt::format_to(std::back_inserter(added_headers),"X-Spam-Action: {}{}",
- action, line_end);
+ fmt::format_to(std::back_inserter(added_headers), "X-Spam-Action: {}{}",
+ action, line_end);
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Score: {:.2f} / {:.2f}{}",
- score, required_score, line_end);
+ score, required_score, line_end);
/* SA style stars header */
std::string scorebuf;
auto adjusted_score = std::min(score, 32.0);
- while(adjusted_score > 0) {
+ while (adjusted_score > 0) {
scorebuf.push_back('*');
adjusted_score -= 1.0;
}
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Level: {}{}",
- scorebuf, line_end);
+ scorebuf, line_end);
/* Short description of all symbols */
std::string symbuf;
@@ -1641,7 +1631,7 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
ucl_object_iter_t it = nullptr;
const auto *syms = ucl_object_lookup(result, "symbols");
- while (syms && (cur = ucl_object_iterate (syms, &it, true)) != nullptr) {
+ while (syms && (cur = ucl_object_iterate(syms, &it, true)) != nullptr) {
if (ucl_object_type(cur) == UCL_OBJECT) {
fmt::format_to(std::back_inserter(symbuf), "{},", ucl_object_key(cur));
}
@@ -1652,23 +1642,23 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
}
auto *folded_symbuf = rspamd_header_value_fold("X-Spam-Symbols", strlen("X-Spam-Symbols"),
- symbuf.data(), symbuf.size(),
- 0, nl_type, ",");
+ symbuf.data(), symbuf.size(),
+ 0, nl_type, ",");
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Symbols: {}{}",
- folded_symbuf->str, line_end);
+ folded_symbuf->str, line_end);
g_string_free(folded_symbuf, TRUE);
res = ucl_object_lookup(result, "dkim-signature");
if (res && res->type == UCL_STRING) {
fmt::format_to(std::back_inserter(added_headers), "DKIM-Signature: {}{}",
- ucl_object_tostring(res), line_end);
+ ucl_object_tostring(res), line_end);
}
else if (res && res->type == UCL_ARRAY) {
it = nullptr;
- while ((cur = ucl_object_iterate (res, &it, true)) != nullptr) {
+ while ((cur = ucl_object_iterate(res, &it, true)) != nullptr) {
fmt::format_to(std::back_inserter(added_headers), "DKIM-Signature: {}{}",
- ucl_object_tostring(cur), line_end);
+ ucl_object_tostring(cur), line_end);
}
}
@@ -1677,19 +1667,19 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
/* We also append json data as a specific header */
if (json) {
json_header = ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
}
else {
json_header = ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
}
auto *json_header_encoded = rspamd_encode_base64_fold(json_header,
- strlen((char *)json_header), 60, nullptr, nl_type);
+ strlen((char *) json_header), 60, nullptr, nl_type);
free(json_header);
fmt::format_to(std::back_inserter(added_headers),
- "X-Spam-Result: {}{}",
- json_header_encoded, line_end);
+ "X-Spam-Result: {}{}",
+ json_header_encoded, line_end);
g_free(json_header_encoded);
}
@@ -1697,16 +1687,16 @@ rspamc_mime_output(FILE *out, ucl_object_t *result, GString *input,
}
else {
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Scanner: {}{}",
- "rspamc " RVERSION, line_end);
+ "rspamc " RVERSION, line_end);
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Scan-Time: {:.3f}{}",
- time, line_end);
+ time, line_end);
fmt::format_to(std::back_inserter(added_headers), "X-Spam-Error: {}{}",
- err->message, line_end);
+ err->message, line_end);
}
/* Write message */
/* Original headers */
- fmt::print(out, "{}", std::string_view{input->str, (std::size_t)headers_pos});
+ fmt::print(out, "{}", std::string_view{input->str, (std::size_t) headers_pos});
/* Added headers */
fmt::print(out, "{}", added_headers);
/* Message body */
@@ -1730,8 +1720,8 @@ rspamc_client_execute_cmd(const struct rspamc_command &cmd, ucl_object_t *result
}
if (!g_spawn_async_with_pipes(nullptr, eargv, nullptr,
- static_cast<GSpawnFlags>(G_SPAWN_SEARCH_PATH | G_SPAWN_DO_NOT_REAP_CHILD), nullptr, nullptr, &cld,
- &infd, &outfd, &errfd, &exec_err)) {
+ static_cast<GSpawnFlags>(G_SPAWN_SEARCH_PATH | G_SPAWN_DO_NOT_REAP_CHILD), nullptr, nullptr, &cld,
+ &infd, &outfd, &errfd, &exec_err)) {
fmt::print(stderr, "Cannot execute {}: {}", execute, exec_err->message);
g_error_free(exec_err);
@@ -1750,12 +1740,12 @@ rspamc_client_execute_cmd(const struct rspamc_command &cmd, ucl_object_t *result
char *ucl_out;
if (json) {
- ucl_out = (char *)ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
+ ucl_out = (char *) ucl_object_emit(result,
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
}
else {
- ucl_out = (char *)ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
+ ucl_out = (char *) ucl_object_emit(result,
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
}
fmt::print(out, "{}", ucl_out);
free(ucl_out);
@@ -1820,13 +1810,13 @@ rspamc_client_cb(struct rspamd_client_connection *conn,
if (cmd.need_input && !json) {
if (!compact && !humanreport) {
fmt::print(out, "Results for file: {} ({:.3} seconds)\n",
- emphasis_argument(cbdata->filename), diff);
+ emphasis_argument(cbdata->filename), diff);
}
}
else {
if (!compact && !json && !humanreport) {
fmt::print(out, "Results for command: {} ({:.3} seconds)\n",
- emphasis_argument(cmd.name), diff);
+ emphasis_argument(cmd.name), diff);
}
}
@@ -1837,25 +1827,25 @@ rspamc_client_cb(struct rspamd_client_connection *conn,
if (ucl_reply || cmd.command_output_func == nullptr) {
if (cmd.need_input) {
ucl_object_insert_key(result,
- ucl_object_fromstring(cbdata->filename.c_str()),
- "filename", 0,
- false);
+ ucl_object_fromstring(cbdata->filename.c_str()),
+ "filename", 0,
+ false);
}
ucl_object_insert_key(result,
- ucl_object_fromdouble(diff),
- "scan_time", 0,
- false);
+ ucl_object_fromdouble(diff),
+ "scan_time", 0,
+ false);
char *ucl_out;
if (json) {
- ucl_out = (char *)ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
+ ucl_out = (char *) ucl_object_emit(result,
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_JSON);
}
else {
- ucl_out = (char *)ucl_object_emit(result,
- compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
+ ucl_out = (char *) ucl_object_emit(result,
+ compact ? UCL_EMIT_JSON_COMPACT : UCL_EMIT_CONFIG);
}
fmt::print(out, "{}", ucl_out);
@@ -1867,7 +1857,7 @@ rspamc_client_cb(struct rspamd_client_connection *conn,
if (body) {
fmt::print(out, "\nNew body:\n{}\n",
- std::string_view{body, bodylen});
+ std::string_view{body, bodylen});
}
ucl_object_unref(result);
@@ -1946,7 +1936,7 @@ rspamc_process_input(struct ev_loop *ev_base, const struct rspamc_command &cmd,
*/
if (hostbuf == "localhost" ||
- hostbuf == "127.0.0.1"||
+ hostbuf == "127.0.0.1" ||
hostbuf == "::1" ||
hostbuf == "[::1]") {
port = DEFAULT_CONTROL_PORT;
@@ -1954,7 +1944,6 @@ rspamc_process_input(struct ev_loop *ev_base, const struct rspamc_command &cmd,
else {
port = cmd.is_controller ? DEFAULT_CONTROL_PORT : DEFAULT_PORT;
}
-
}
conn = rspamd_client_init(http_ctx, ev_base, hostbuf.c_str(), port, timeout, pubkey);
@@ -1966,24 +1955,24 @@ rspamc_process_input(struct ev_loop *ev_base, const struct rspamc_command &cmd,
if (cmd.need_input) {
rspamd_client_command(conn, cmd.path, attrs, in, rspamc_client_cb,
- cbdata, compressed, dictionary, cbdata->filename.c_str(), &err);
+ cbdata, compressed, dictionary, cbdata->filename.c_str(), &err);
}
else {
rspamd_client_command(conn,
- cmd.path,
- attrs,
- nullptr,
- rspamc_client_cb,
- cbdata,
- compressed,
- dictionary,
- cbdata->filename.c_str(),
- &err);
+ cmd.path,
+ attrs,
+ nullptr,
+ rspamc_client_cb,
+ cbdata,
+ compressed,
+ dictionary,
+ cbdata->filename.c_str(),
+ &err);
}
}
else {
fmt::print(stderr, "cannot connect to {}: {}\n", connect_str,
- strerror(errno));
+ strerror(errno));
exit(EXIT_FAILURE);
}
}
@@ -1994,29 +1983,28 @@ rspamd_dirent_size(DIR *dirp)
goffset name_max;
gsize name_end;
-#if defined(HAVE_FPATHCONF) && defined(HAVE_DIRFD) \
- && defined(_PC_NAME_MAX)
+#if defined(HAVE_FPATHCONF) && defined(HAVE_DIRFD) && defined(_PC_NAME_MAX)
name_max = fpathconf(dirfd(dirp), _PC_NAME_MAX);
-# if defined(NAME_MAX)
+#if defined(NAME_MAX)
if (name_max == -1) {
name_max = (NAME_MAX > 255) ? NAME_MAX : 255;
}
-# else
+#else
if (name_max == -1) {
- return (size_t)(-1);
+ return (size_t) (-1);
}
-# endif
+#endif
#else
- # if defined(NAME_MAX)
+#if defined(NAME_MAX)
name_max = (NAME_MAX > 255) ? NAME_MAX : 255;
-# else
-# error "buffer size for readdir_r cannot be determined"
-# endif
+#else
+#error "buffer size for readdir_r cannot be determined"
+#endif
#endif
- name_end = G_STRUCT_OFFSET (struct dirent, d_name) + name_max + 1;
+ name_end = G_STRUCT_OFFSET(struct dirent, d_name) + name_max + 1;
return (name_end > sizeof(struct dirent) ? name_end : sizeof(struct dirent));
}
@@ -2042,8 +2030,8 @@ rspamc_process_dir(struct ev_loop *ev_base, const struct rspamc_command &cmd,
fpath.clear();
fmt::format_to(std::back_inserter(fpath), "{}{}{}",
- name, G_DIR_SEPARATOR,
- pentry->d_name);
+ name, G_DIR_SEPARATOR,
+ pentry->d_name);
/* Check exclude */
auto **ex = exclude_compiled;
@@ -2052,7 +2040,7 @@ rspamc_process_dir(struct ev_loop *ev_base, const struct rspamc_command &cmd,
#if GLIB_MAJOR_VERSION >= 2 && GLIB_MINOR_VERSION >= 70
if (g_pattern_spec_match(*ex, fpath.size(), fpath.c_str(), nullptr)) {
#else
- if (g_pattern_match(*ex, fpath.size(), fpath.c_str(), nullptr)) {
+ if (g_pattern_match(*ex, fpath.size(), fpath.c_str(), nullptr)) {
#endif
skip = true;
break;
@@ -2074,7 +2062,7 @@ rspamc_process_dir(struct ev_loop *ev_base, const struct rspamc_command &cmd,
/* Fallback to lstat */
if (lstat(fpath.c_str(), &st) == -1) {
fmt::print(stderr, "cannot stat file {}: {}\n",
- fpath, strerror(errno));
+ fpath, strerror(errno));
continue;
}
@@ -2092,7 +2080,7 @@ rspamc_process_dir(struct ev_loop *ev_base, const struct rspamc_command &cmd,
#else
if (lstat(fpath.c_str(), &st) == -1) {
fmt::print(stderr, "cannot stat file {}: {}\n",
- fpath, strerror (errno));
+ fpath, strerror(errno));
continue;
}
@@ -2107,7 +2095,7 @@ rspamc_process_dir(struct ev_loop *ev_base, const struct rspamc_command &cmd,
auto *in = fopen(fpath.c_str(), "r");
if (in == nullptr) {
fmt::print(stderr, "cannot open file {}: {}\n",
- fpath, strerror(errno));
+ fpath, strerror(errno));
continue;
}
@@ -2143,8 +2131,7 @@ rspamc_kwattr_free(gpointer p)
g_free(h);
}
-int
-main(int argc, char **argv, char **env)
+int main(int argc, char **argv, char **env)
{
auto *kwattrs = g_queue_new();
@@ -2173,7 +2160,7 @@ main(int argc, char **argv, char **env)
if (exclude_compiled[i] == nullptr) {
fmt::print(stderr, "Invalid glob pattern: {}\n",
- exclude_patterns[i]);
+ exclude_patterns[i]);
exit(EXIT_FAILURE);
}
}
@@ -2188,12 +2175,12 @@ main(int argc, char **argv, char **env)
http_config.kp_cache_size_server = 0;
http_config.user_agent = user_agent;
http_ctx = rspamd_http_context_create_config(&http_config,
- event_loop, nullptr);
+ event_loop, nullptr);
/* Ignore sigpipe */
struct sigaction sigpipe_act;
- sigemptyset (&sigpipe_act.sa_mask);
- sigaddset (&sigpipe_act.sa_mask, SIGPIPE);
+ sigemptyset(&sigpipe_act.sa_mask);
+ sigaddset(&sigpipe_act.sa_mask, SIGPIPE);
sigpipe_act.sa_handler = SIG_IGN;
sigpipe_act.sa_flags = 0;
sigaction(SIGPIPE, &sigpipe_act, nullptr);
@@ -2283,7 +2270,7 @@ main(int argc, char **argv, char **env)
fmt::print(stderr, "cannot stat file {}\n", argv[i]);
exit(EXIT_FAILURE);
}
- if (S_ISDIR (st.st_mode)) {
+ if (S_ISDIR(st.st_mode)) {
/* Directories are processed with a separate limit */
rspamc_process_dir(event_loop, cmd, argv[i], kwattrs);
cur_req = 0;
@@ -2318,22 +2305,22 @@ main(int argc, char **argv, char **env)
/* Wait for children processes */
auto ret = 0;
- for (auto cld : children) {
+ for (auto cld: children) {
auto res = 0;
if (waitpid(cld, &res, 0) == -1) {
fmt::print(stderr, "Cannot wait for {}: {}", cld,
- strerror(errno));
+ strerror(errno));
ret = errno;
}
if (ret == 0) {
/* Check return code */
- if (WIFSIGNALED (res)) {
- ret = WTERMSIG (res);
+ if (WIFSIGNALED(res)) {
+ ret = WTERMSIG(res);
}
- else if (WIFEXITED (res)) {
- ret = WEXITSTATUS (res);
+ else if (WIFEXITED(res)) {
+ ret = WEXITSTATUS(res);
}
}
}
diff --git a/src/client/rspamdclient.c b/src/client/rspamdclient.c
index f9f337864..85f4749f1 100644
--- a/src/client/rspamdclient.c
+++ b/src/client/rspamdclient.c
@@ -21,9 +21,9 @@
#include "unix-std.h"
#ifdef SYS_ZSTD
-# include "zstd.h"
+#include "zstd.h"
#else
-# include "contrib/zstd/zstd.h"
+#include "contrib/zstd/zstd.h"
#endif
#ifdef HAVE_FETCH_H
@@ -60,56 +60,56 @@ struct rspamd_client_request {
gpointer ud;
};
-#define RCLIENT_ERROR rspamd_client_error_quark ()
+#define RCLIENT_ERROR rspamd_client_error_quark()
GQuark
-rspamd_client_error_quark (void)
+rspamd_client_error_quark(void)
{
- return g_quark_from_static_string ("rspamd-client-error");
+ return g_quark_from_static_string("rspamd-client-error");
}
static void
-rspamd_client_request_free (struct rspamd_client_request *req)
+rspamd_client_request_free(struct rspamd_client_request *req)
{
if (req != NULL) {
if (req->conn) {
req->conn->req = NULL;
}
if (req->input) {
- g_string_free (req->input, TRUE);
+ g_string_free(req->input, TRUE);
}
- g_free (req);
+ g_free(req);
}
}
static gint
-rspamd_client_body_handler (struct rspamd_http_connection *conn,
- struct rspamd_http_message *msg,
- const gchar *chunk, gsize len)
+rspamd_client_body_handler(struct rspamd_http_connection *conn,
+ struct rspamd_http_message *msg,
+ const gchar *chunk, gsize len)
{
/* Do nothing here */
return 0;
}
static void
-rspamd_client_error_handler (struct rspamd_http_connection *conn, GError *err)
+rspamd_client_error_handler(struct rspamd_http_connection *conn, GError *err)
{
struct rspamd_client_request *req =
- (struct rspamd_client_request *)conn->ud;
+ (struct rspamd_client_request *) conn->ud;
struct rspamd_client_connection *c;
c = req->conn;
- req->cb (c, NULL, c->server_name->str, NULL,
+ req->cb(c, NULL, c->server_name->str, NULL,
req->input, req->ud,
c->start_time, c->send_time, NULL, 0, err);
}
static gint
-rspamd_client_finish_handler (struct rspamd_http_connection *conn,
- struct rspamd_http_message *msg)
+rspamd_client_finish_handler(struct rspamd_http_connection *conn,
+ struct rspamd_http_message *msg)
{
struct rspamd_client_request *req =
- (struct rspamd_client_request *)conn->ud;
+ (struct rspamd_client_request *) conn->ud;
struct rspamd_client_connection *c;
struct ucl_parser *parser;
GError *err;
@@ -122,27 +122,27 @@ rspamd_client_finish_handler (struct rspamd_http_connection *conn,
if (!c->req_sent) {
c->req_sent = TRUE;
- c->send_time = rspamd_get_ticks (FALSE);
- rspamd_http_connection_reset (c->http_conn);
- rspamd_http_connection_read_message (c->http_conn,
- c->req,
- c->timeout);
+ c->send_time = rspamd_get_ticks(FALSE);
+ rspamd_http_connection_reset(c->http_conn);
+ rspamd_http_connection_read_message(c->http_conn,
+ c->req,
+ c->timeout);
return 0;
}
else {
- if (rspamd_http_message_get_body (msg, NULL) == NULL || msg->code / 100 != 2) {
- err = g_error_new (RCLIENT_ERROR, msg->code, "HTTP error: %d, %.*s",
- msg->code,
- (gint)msg->status->len, msg->status->str);
- req->cb (c, msg, c->server_name->str, NULL, req->input, req->ud,
+ if (rspamd_http_message_get_body(msg, NULL) == NULL || msg->code / 100 != 2) {
+ err = g_error_new(RCLIENT_ERROR, msg->code, "HTTP error: %d, %.*s",
+ msg->code,
+ (gint) msg->status->len, msg->status->str);
+ req->cb(c, msg, c->server_name->str, NULL, req->input, req->ud,
c->start_time, c->send_time, body, bodylen, err);
- g_error_free (err);
+ g_error_free(err);
return 0;
}
- tok = rspamd_http_message_find_header (msg, COMPRESSION_HEADER);
+ tok = rspamd_http_message_find_header(msg, COMPRESSION_HEADER);
if (tok) {
/* Need to uncompress */
@@ -151,40 +151,40 @@ rspamd_client_finish_handler (struct rspamd_http_connection *conn,
t.begin = "zstd";
t.len = 4;
- if (rspamd_ftok_casecmp (tok, &t) == 0) {
+ if (rspamd_ftok_casecmp(tok, &t) == 0) {
ZSTD_DStream *zstream;
ZSTD_inBuffer zin;
ZSTD_outBuffer zout;
gsize outlen, r;
- zstream = ZSTD_createDStream ();
- ZSTD_initDStream (zstream);
+ zstream = ZSTD_createDStream();
+ ZSTD_initDStream(zstream);
zin.pos = 0;
zin.src = msg->body_buf.begin;
zin.size = msg->body_buf.len;
- if ((outlen = ZSTD_getDecompressedSize (zin.src, zin.size)) == 0) {
- outlen = ZSTD_DStreamOutSize ();
+ if ((outlen = ZSTD_getDecompressedSize(zin.src, zin.size)) == 0) {
+ outlen = ZSTD_DStreamOutSize();
}
- out = g_malloc (outlen);
+ out = g_malloc(outlen);
zout.dst = out;
zout.pos = 0;
zout.size = outlen;
while (zin.pos < zin.size) {
- r = ZSTD_decompressStream (zstream, &zout, &zin);
+ r = ZSTD_decompressStream(zstream, &zout, &zin);
- if (ZSTD_isError (r)) {
- err = g_error_new (RCLIENT_ERROR, 500,
- "Decompression error: %s",
- ZSTD_getErrorName (r));
- req->cb (c, msg, c->server_name->str, NULL,
+ if (ZSTD_isError(r)) {
+ err = g_error_new(RCLIENT_ERROR, 500,
+ "Decompression error: %s",
+ ZSTD_getErrorName(r));
+ req->cb(c, msg, c->server_name->str, NULL,
req->input, req->ud, c->start_time,
c->send_time, body, bodylen, err);
- g_error_free (err);
- ZSTD_freeDStream (zstream);
+ g_error_free(err);
+ ZSTD_freeDStream(zstream);
goto end;
}
@@ -192,22 +192,22 @@ rspamd_client_finish_handler (struct rspamd_http_connection *conn,
if (zout.pos == zout.size) {
/* We need to extend output buffer */
zout.size = zout.size * 2;
- zout.dst = g_realloc (zout.dst, zout.size);
+ zout.dst = g_realloc(zout.dst, zout.size);
}
}
- ZSTD_freeDStream (zstream);
+ ZSTD_freeDStream(zstream);
start = zout.dst;
len = zout.pos;
}
else {
- err = g_error_new (RCLIENT_ERROR, 500,
- "Invalid compression method");
- req->cb (c, msg, c->server_name->str, NULL,
+ err = g_error_new(RCLIENT_ERROR, 500,
+ "Invalid compression method");
+ req->cb(c, msg, c->server_name->str, NULL,
req->input, req->ud, c->start_time, c->send_time,
body, bodylen, err);
- g_error_free (err);
+ g_error_free(err);
return 0;
}
@@ -218,98 +218,98 @@ rspamd_client_finish_handler (struct rspamd_http_connection *conn,
}
/* Deal with body */
- tok = rspamd_http_message_find_header (msg, MESSAGE_OFFSET_HEADER);
+ tok = rspamd_http_message_find_header(msg, MESSAGE_OFFSET_HEADER);
if (tok) {
gulong value = 0;
- if (rspamd_strtoul (tok->begin, tok->len, &value) &&
- value < len) {
+ if (rspamd_strtoul(tok->begin, tok->len, &value) &&
+ value < len) {
body = start + value;
bodylen = len - value;
len = value;
}
}
- parser = ucl_parser_new (0);
- if (!ucl_parser_add_chunk (parser, start, len)) {
- err = g_error_new (RCLIENT_ERROR, msg->code, "Cannot parse UCL: %s",
- ucl_parser_get_error (parser));
- ucl_parser_free (parser);
- req->cb (c, msg, c->server_name->str, NULL,
+ parser = ucl_parser_new(0);
+ if (!ucl_parser_add_chunk(parser, start, len)) {
+ err = g_error_new(RCLIENT_ERROR, msg->code, "Cannot parse UCL: %s",
+ ucl_parser_get_error(parser));
+ ucl_parser_free(parser);
+ req->cb(c, msg, c->server_name->str, NULL,
req->input, req->ud,
c->start_time, c->send_time, body, bodylen, err);
- g_error_free (err);
+ g_error_free(err);
goto end;
}
- req->cb (c, msg, c->server_name->str,
- ucl_parser_get_object (parser),
+ req->cb(c, msg, c->server_name->str,
+ ucl_parser_get_object(parser),
req->input, req->ud,
c->start_time, c->send_time, body, bodylen, NULL);
- ucl_parser_free (parser);
+ ucl_parser_free(parser);
}
end:
if (out) {
- g_free (out);
+ g_free(out);
}
return 0;
}
struct rspamd_client_connection *
-rspamd_client_init (struct rspamd_http_context *http_ctx,
- struct ev_loop *ev_base, const gchar *name,
- guint16 port, gdouble timeout, const gchar *key)
+rspamd_client_init(struct rspamd_http_context *http_ctx,
+ struct ev_loop *ev_base, const gchar *name,
+ guint16 port, gdouble timeout, const gchar *key)
{
struct rspamd_client_connection *conn;
gint fd;
- fd = rspamd_socket (name, port, SOCK_STREAM, TRUE, FALSE, TRUE);
+ fd = rspamd_socket(name, port, SOCK_STREAM, TRUE, FALSE, TRUE);
if (fd == -1) {
return NULL;
}
- conn = g_malloc0 (sizeof (struct rspamd_client_connection));
+ conn = g_malloc0(sizeof(struct rspamd_client_connection));
conn->event_loop = ev_base;
conn->fd = fd;
conn->req_sent = FALSE;
- conn->http_conn = rspamd_http_connection_new_client_socket (http_ctx,
- rspamd_client_body_handler,
- rspamd_client_error_handler,
- rspamd_client_finish_handler,
- 0,
- fd);
+ conn->http_conn = rspamd_http_connection_new_client_socket(http_ctx,
+ rspamd_client_body_handler,
+ rspamd_client_error_handler,
+ rspamd_client_finish_handler,
+ 0,
+ fd);
if (!conn->http_conn) {
- rspamd_client_destroy (conn);
+ rspamd_client_destroy(conn);
return NULL;
}
/* Pass socket ownership */
- rspamd_http_connection_own_socket (conn->http_conn);
- conn->server_name = g_string_new (name);
+ rspamd_http_connection_own_socket(conn->http_conn);
+ conn->server_name = g_string_new(name);
if (port != 0) {
- rspamd_printf_gstring (conn->server_name, ":%d", (int)port);
+ rspamd_printf_gstring(conn->server_name, ":%d", (int) port);
}
conn->timeout = timeout;
if (key) {
- conn->key = rspamd_pubkey_from_base32 (key, 0, RSPAMD_KEYPAIR_KEX,
- RSPAMD_CRYPTOBOX_MODE_25519);
+ conn->key = rspamd_pubkey_from_base32(key, 0, RSPAMD_KEYPAIR_KEX,
+ RSPAMD_CRYPTOBOX_MODE_25519);
if (conn->key) {
- conn->keypair = rspamd_keypair_new (RSPAMD_KEYPAIR_KEX,
- RSPAMD_CRYPTOBOX_MODE_25519);
- rspamd_http_connection_set_key (conn->http_conn, conn->keypair);
+ conn->keypair = rspamd_keypair_new(RSPAMD_KEYPAIR_KEX,
+ RSPAMD_CRYPTOBOX_MODE_25519);
+ rspamd_http_connection_set_key(conn->http_conn, conn->keypair);
}
else {
- rspamd_client_destroy (conn);
+ rspamd_client_destroy(conn);
return NULL;
}
}
@@ -318,13 +318,13 @@ rspamd_client_init (struct rspamd_http_context *http_ctx,
}
gboolean
-rspamd_client_command (struct rspamd_client_connection *conn,
- const gchar *command, GQueue *attrs,
- FILE *in, rspamd_client_callback cb,
- gpointer ud, gboolean compressed,
- const gchar *comp_dictionary,
- const gchar *filename,
- GError **err)
+rspamd_client_command(struct rspamd_client_connection *conn,
+ const gchar *command, GQueue *attrs,
+ FILE *in, rspamd_client_callback cb,
+ gpointer ud, gboolean compressed,
+ const gchar *comp_dictionary,
+ const gchar *filename,
+ GError **err)
{
struct rspamd_client_request *req;
struct rspamd_http_client_header *nh;
@@ -339,62 +339,61 @@ rspamd_client_command (struct rspamd_client_connection *conn,
ZSTD_CCtx *zctx;
gboolean ret;
- req = g_malloc0 (sizeof (struct rspamd_client_request));
+ req = g_malloc0(sizeof(struct rspamd_client_request));
req->conn = conn;
req->cb = cb;
req->ud = ud;
- req->msg = rspamd_http_new_message (HTTP_REQUEST);
+ req->msg = rspamd_http_new_message(HTTP_REQUEST);
if (conn->key) {
- req->msg->peer_key = rspamd_pubkey_ref (conn->key);
+ req->msg->peer_key = rspamd_pubkey_ref(conn->key);
}
if (in != NULL) {
/* Read input stream */
- input = g_string_sized_new (BUFSIZ);
+ input = g_string_sized_new(BUFSIZ);
- while (!feof (in)) {
+ while (!feof(in)) {
p = input->str + input->len;
remain = input->allocated_len - input->len - 1;
if (remain == 0) {
old_len = input->len;
- g_string_set_size (input, old_len * 2);
+ g_string_set_size(input, old_len * 2);
input->len = old_len;
continue;
}
- remain = fread (p, 1, remain, in);
+ remain = fread(p, 1, remain, in);
if (remain > 0) {
input->len += remain;
input->str[input->len] = '\0';
}
}
- if (ferror (in) != 0) {
- g_set_error (err, RCLIENT_ERROR, ferror (
- in), "input IO error: %s", strerror (ferror (in)));
- g_free (req);
- g_string_free (input, TRUE);
+ if (ferror(in) != 0) {
+ g_set_error(err, RCLIENT_ERROR, ferror(in), "input IO error: %s", strerror(ferror(in)));
+ g_free(req);
+ g_string_free(input, TRUE);
return FALSE;
}
if (!compressed) {
/* Detect zstd input */
- if (input->len > 4 && memcmp (input->str, "\x28\xb5\x2f\xfd", 4) == 0) {
+ if (input->len > 4 && memcmp(input->str, "\x28\xb5\x2f\xfd", 4) == 0) {
compressed = TRUE;
}
- body = rspamd_fstring_new_init (input->str, input->len);
+ body = rspamd_fstring_new_init(input->str, input->len);
}
else {
if (comp_dictionary) {
- dict = rspamd_file_xmap (comp_dictionary, PROT_READ, &dict_len,
- TRUE);
+ dict = rspamd_file_xmap(comp_dictionary, PROT_READ, &dict_len,
+ TRUE);
if (dict == NULL) {
- g_set_error (err, RCLIENT_ERROR, errno,
- "cannot open dictionary %s: %s",
- comp_dictionary,
- strerror (errno));
- g_free (req);
- g_string_free (input, TRUE);
+ g_set_error(err, RCLIENT_ERROR, errno,
+ "cannot open dictionary %s: %s",
+ comp_dictionary,
+ strerror(errno));
+ g_free(req);
+ g_string_free(input, TRUE);
return FALSE;
}
@@ -402,30 +401,29 @@ rspamd_client_command (struct rspamd_client_connection *conn,
dict_id = -1;
}
- body = rspamd_fstring_sized_new (ZSTD_compressBound (input->len));
- zctx = ZSTD_createCCtx ();
- body->len = ZSTD_compress_usingDict (zctx, body->str, body->allocated,
- input->str, input->len,
- dict, dict_len,
- 1);
+ body = rspamd_fstring_sized_new(ZSTD_compressBound(input->len));
+ zctx = ZSTD_createCCtx();
+ body->len = ZSTD_compress_usingDict(zctx, body->str, body->allocated,
+ input->str, input->len,
+ dict, dict_len,
+ 1);
- munmap (dict, dict_len);
+ munmap(dict, dict_len);
- if (ZSTD_isError (body->len)) {
- g_set_error (err, RCLIENT_ERROR, ferror (
- in), "compression error");
- g_free (req);
- g_string_free (input, TRUE);
- rspamd_fstring_free (body);
- ZSTD_freeCCtx (zctx);
+ if (ZSTD_isError(body->len)) {
+ g_set_error(err, RCLIENT_ERROR, ferror(in), "compression error");
+ g_free(req);
+ g_string_free(input, TRUE);
+ rspamd_fstring_free(body);
+ ZSTD_freeCCtx(zctx);
return FALSE;
}
- ZSTD_freeCCtx (zctx);
+ ZSTD_freeCCtx(zctx);
}
- rspamd_http_message_set_body_from_fstring_steal (req->msg, body);
+ rspamd_http_message_set_body_from_fstring_steal(req->msg, body);
req->input = input;
}
else {
@@ -437,65 +435,64 @@ rspamd_client_command (struct rspamd_client_connection *conn,
while (cur != NULL) {
nh = cur->data;
- rspamd_http_message_add_header (req->msg, nh->name, nh->value);
- cur = g_list_next (cur);
+ rspamd_http_message_add_header(req->msg, nh->name, nh->value);
+ cur = g_list_next(cur);
}
if (compressed) {
- rspamd_http_message_add_header (req->msg, COMPRESSION_HEADER, "zstd");
+ rspamd_http_message_add_header(req->msg, COMPRESSION_HEADER, "zstd");
if (dict_id != 0) {
gchar dict_str[32];
- rspamd_snprintf (dict_str, sizeof (dict_str), "%ud", dict_id);
- rspamd_http_message_add_header (req->msg, "Dictionary", dict_str);
+ rspamd_snprintf(dict_str, sizeof(dict_str), "%ud", dict_id);
+ rspamd_http_message_add_header(req->msg, "Dictionary", dict_str);
}
}
if (filename) {
- rspamd_http_message_add_header (req->msg, "Filename", filename);
+ rspamd_http_message_add_header(req->msg, "Filename", filename);
}
- req->msg->url = rspamd_fstring_append (req->msg->url, "/", 1);
- req->msg->url = rspamd_fstring_append (req->msg->url, command, strlen (command));
+ req->msg->url = rspamd_fstring_append(req->msg->url, "/", 1);
+ req->msg->url = rspamd_fstring_append(req->msg->url, command, strlen(command));
conn->req = req;
- conn->start_time = rspamd_get_ticks (FALSE);
+ conn->start_time = rspamd_get_ticks(FALSE);
if (compressed) {
- ret = rspamd_http_connection_write_message (conn->http_conn, req->msg,
- NULL,"application/x-compressed", req,
- conn->timeout);
+ ret = rspamd_http_connection_write_message(conn->http_conn, req->msg,
+ NULL, "application/x-compressed", req,
+ conn->timeout);
}
else {
- ret = rspamd_http_connection_write_message (conn->http_conn, req->msg,
- NULL,"text/plain", req, conn->timeout);
+ ret = rspamd_http_connection_write_message(conn->http_conn, req->msg,
+ NULL, "text/plain", req, conn->timeout);
}
return ret;
}
-void
-rspamd_client_destroy (struct rspamd_client_connection *conn)
+void rspamd_client_destroy(struct rspamd_client_connection *conn)
{
if (conn != NULL) {
if (conn->http_conn) {
- rspamd_http_connection_unref (conn->http_conn);
+ rspamd_http_connection_unref(conn->http_conn);
}
if (conn->req != NULL) {
- rspamd_client_request_free (conn->req);
+ rspamd_client_request_free(conn->req);
}
if (conn->key) {
- rspamd_pubkey_unref (conn->key);
+ rspamd_pubkey_unref(conn->key);
}
if (conn->keypair) {
- rspamd_keypair_unref (conn->keypair);
+ rspamd_keypair_unref(conn->keypair);
}
- g_string_free (conn->server_name, TRUE);
- g_free (conn);
+ g_string_free(conn->server_name, TRUE);
+ g_free(conn);
}
}
diff --git a/src/client/rspamdclient.h b/src/client/rspamdclient.h
index b42abebda..27597dfb2 100644
--- a/src/client/rspamdclient.h
+++ b/src/client/rspamdclient.h
@@ -20,7 +20,7 @@
#include "ucl.h"
#include "contrib/libev/ev.h"
-#ifdef __cplusplus
+#ifdef __cplusplus
extern "C" {
#endif
@@ -40,18 +40,18 @@ struct rspamd_http_client_header {
* @param ud opaque user data
* @param err error pointer
*/
-typedef void (*rspamd_client_callback) (
- struct rspamd_client_connection *conn,
- struct rspamd_http_message *msg,
- const gchar *name,
- ucl_object_t *result,
- GString *input,
- gpointer ud,
- gdouble start_time,
- gdouble send_time,
- const gchar *body,
- gsize body_len,
- GError *err);
+typedef void (*rspamd_client_callback)(
+ struct rspamd_client_connection *conn,
+ struct rspamd_http_message *msg,
+ const gchar *name,
+ ucl_object_t *result,
+ GString *input,
+ gpointer ud,
+ gdouble start_time,
+ gdouble send_time,
+ const gchar *body,
+ gsize body_len,
+ GError *err);
struct rspamd_http_context;
@@ -63,13 +63,13 @@ struct rspamd_http_context;
* @param timeout timeout in seconds
* @return
*/
-struct rspamd_client_connection *rspamd_client_init (
- struct rspamd_http_context *http_ctx,
- struct ev_loop *ev_base,
- const gchar *name,
- guint16 port,
- gdouble timeout,
- const gchar *key);
+struct rspamd_client_connection *rspamd_client_init(
+ struct rspamd_http_context *http_ctx,
+ struct ev_loop *ev_base,
+ const gchar *name,
+ guint16 port,
+ gdouble timeout,
+ const gchar *key);
/**
*
@@ -81,25 +81,25 @@ struct rspamd_client_connection *rspamd_client_init (
* @param ud opaque user data
* @return
*/
-gboolean rspamd_client_command (
- struct rspamd_client_connection *conn,
- const gchar *command,
- GQueue *attrs,
- FILE *in,
- rspamd_client_callback cb,
- gpointer ud,
- gboolean compressed,
- const gchar *comp_dictionary,
- const gchar *filename,
- GError **err);
+gboolean rspamd_client_command(
+ struct rspamd_client_connection *conn,
+ const gchar *command,
+ GQueue *attrs,
+ FILE *in,
+ rspamd_client_callback cb,
+ gpointer ud,
+ gboolean compressed,
+ const gchar *comp_dictionary,
+ const gchar *filename,
+ GError **err);
/**
* Destroy a connection to rspamd
* @param conn
*/
-void rspamd_client_destroy (struct rspamd_client_connection *conn);
+void rspamd_client_destroy(struct rspamd_client_connection *conn);
-#ifdef __cplusplus
+#ifdef __cplusplus
}
#endif