summaryrefslogtreecommitdiffstats
path: root/src/client
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-11-15 21:40:51 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-11-15 21:40:51 +0000
commit57d1fc752a122e2fa3a89ec3d01e1c7a555de2fa (patch)
treef4643b346b2e9ef7569f6554059891219b6e6a48 /src/client
parent61ba512c5d8b5cce43a8d78630cfe5ee9c0768b0 (diff)
downloadrspamd-57d1fc752a122e2fa3a89ec3d01e1c7a555de2fa.tar.gz
rspamd-57d1fc752a122e2fa3a89ec3d01e1c7a555de2fa.zip
Allow multiple headers with the same name
Diffstat (limited to 'src/client')
-rw-r--r--src/client/rspamc.c66
-rw-r--r--src/client/rspamdclient.c16
-rw-r--r--src/client/rspamdclient.h7
3 files changed, 54 insertions, 35 deletions
diff --git a/src/client/rspamc.c b/src/client/rspamc.c
index 9cbab44a3..6163050a0 100644
--- a/src/client/rspamc.c
+++ b/src/client/rspamc.c
@@ -66,6 +66,14 @@ static gboolean mime_output = FALSE;
static gchar *key = NULL;
static GList *children;
+#define ADD_CLIENT_HEADER(o, n, v) do { \
+ struct rspamd_http_client_header *nh; \
+ nh = g_malloc (sizeof (*nh)); \
+ nh->name = (n); \
+ nh->value = (v); \
+ g_queue_push_tail ((o), nh); \
+} while (0)
+
static GOptionEntry entries[] =
{
{ "connect", 'h', 0, G_OPTION_ARG_STRING, &connect_str,
@@ -390,52 +398,54 @@ print_commands_list (void)
"control commands use port 11334 while normal use 11333 by default (see -h option)\n");
}
-
static void
-add_options (GHashTable *opts)
+add_options (GQueue *opts)
{
GString *numbuf;
- gchar **hdr;
+ gchar **hdr, **rcpt;
if (ip != NULL) {
- g_hash_table_insert (opts, "Ip", ip);
+ ADD_CLIENT_HEADER (opts, "Ip", ip);
}
if (from != NULL) {
- g_hash_table_insert (opts, "From", from);
+ ADD_CLIENT_HEADER (opts, "From", from);
}
if (user != NULL) {
- g_hash_table_insert (opts, "User", user);
+ ADD_CLIENT_HEADER (opts, "User", user);
}
- if (rcpt != NULL) {
- g_hash_table_insert (opts, "Rcpt", rcpt);
+ if (rcpts != NULL) {
+
+ for (rcpt = rcpts; *rcpt != NULL; rcpt ++) {
+ ADD_CLIENT_HEADER (opts, "Rcpt", *rcpt);
+ }
}
if (deliver_to != NULL) {
- g_hash_table_insert (opts, "Deliver-To", deliver_to);
+ ADD_CLIENT_HEADER (opts, "Deliver-To", deliver_to);
}
if (helo != NULL) {
- g_hash_table_insert (opts, "Helo", helo);
+ ADD_CLIENT_HEADER (opts, "Helo", helo);
}
if (hostname != NULL) {
- g_hash_table_insert (opts, "Hostname", hostname);
+ ADD_CLIENT_HEADER (opts, "Hostname", hostname);
}
if (password != NULL) {
- g_hash_table_insert (opts, "Password", password);
+ ADD_CLIENT_HEADER (opts, "Password", password);
}
if (pass_all) {
- g_hash_table_insert (opts, "Pass", "all");
+ ADD_CLIENT_HEADER (opts, "Pass", "all");
}
if (weight != 0) {
numbuf = g_string_sized_new (8);
rspamd_printf_gstring (numbuf, "%d", weight);
- g_hash_table_insert (opts, "Weight", numbuf->str);
+ ADD_CLIENT_HEADER (opts, "Weight", numbuf->str);
}
if (flag != 0) {
numbuf = g_string_sized_new (8);
rspamd_printf_gstring (numbuf, "%d", flag);
- g_hash_table_insert (opts, "Flag", numbuf->str);
+ ADD_CLIENT_HEADER (opts, "Flag", numbuf->str);
}
if (extended_urls) {
- g_hash_table_insert (opts, "URL-Format", "extended");
+ ADD_CLIENT_HEADER (opts, "URL-Format", "extended");
}
hdr = http_headers;
@@ -444,14 +454,14 @@ add_options (GHashTable *opts)
gchar **kv = g_strsplit_set (*hdr, ":=", 2);
if (kv == NULL || kv[1] == NULL) {
- g_hash_table_insert (opts, *hdr, "");
+ ADD_CLIENT_HEADER (opts, *hdr, "");
if (kv) {
g_strfreev (kv);
}
}
else {
- g_hash_table_insert (opts, kv[0], kv[1]);
+ ADD_CLIENT_HEADER (opts, kv[0], kv[1]);
}
hdr ++;
@@ -1222,7 +1232,7 @@ rspamc_client_cb (struct rspamd_client_connection *conn,
static void
rspamc_process_input (struct event_base *ev_base, struct rspamc_command *cmd,
- FILE *in, const gchar *name, GHashTable *attrs)
+ FILE *in, const gchar *name, GQueue *attrs)
{
struct rspamd_client_connection *conn;
gchar **connectv;
@@ -1275,7 +1285,7 @@ rspamc_process_input (struct event_base *ev_base, struct rspamc_command *cmd,
static void
rspamc_process_dir (struct event_base *ev_base, struct rspamc_command *cmd,
- const gchar *name, GHashTable *attrs)
+ const gchar *name, GQueue *attrs)
{
DIR *d;
gint cur_req = 0;
@@ -1329,7 +1339,7 @@ gint
main (gint argc, gchar **argv, gchar **env)
{
gint i, start_argc, cur_req = 0, res;
- GHashTable *kwattrs;
+ GQueue *kwattrs;
GList *cur;
GPid cld;
struct rspamc_command *cmd;
@@ -1338,7 +1348,7 @@ main (gint argc, gchar **argv, gchar **env)
struct stat st;
struct sigaction sigpipe_act;
- kwattrs = g_hash_table_new (rspamd_str_hash, rspamd_str_equal);
+ kwattrs = g_queue_new ();
read_cmd_line (&argc, &argv);
@@ -1386,13 +1396,13 @@ main (gint argc, gchar **argv, gchar **env)
exit (EXIT_FAILURE);
}
if (argc == 5) {
- g_hash_table_insert (kwattrs, "metric", argv[2]);
- g_hash_table_insert (kwattrs, "name", argv[3]);
- g_hash_table_insert (kwattrs, "value", argv[4]);
+ ADD_CLIENT_HEADER (kwattrs, "metric", argv[2]);
+ ADD_CLIENT_HEADER (kwattrs, "name", argv[3]);
+ ADD_CLIENT_HEADER (kwattrs, "value", argv[4]);
}
else {
- g_hash_table_insert (kwattrs, "name", argv[2]);
- g_hash_table_insert (kwattrs, "value", argv[3]);
+ ADD_CLIENT_HEADER (kwattrs, "name", argv[2]);
+ ADD_CLIENT_HEADER (kwattrs, "value", argv[3]);
}
start_argc = argc;
}
@@ -1443,7 +1453,7 @@ main (gint argc, gchar **argv, gchar **env)
event_base_loop (ev_base, 0);
- g_hash_table_destroy (kwattrs);
+ g_queue_free_full (kwattrs, g_free);
/* Wait for children processes */
cur = g_list_first (children);
diff --git a/src/client/rspamdclient.c b/src/client/rspamdclient.c
index 58ea0ad0e..22c822f14 100644
--- a/src/client/rspamdclient.c
+++ b/src/client/rspamdclient.c
@@ -200,14 +200,15 @@ rspamd_client_init (struct event_base *ev_base, const gchar *name,
gboolean
rspamd_client_command (struct rspamd_client_connection *conn,
- const gchar *command, GHashTable *attrs,
+ const gchar *command, GQueue *attrs,
FILE *in, rspamd_client_callback cb,
gpointer ud, GError **err)
{
struct rspamd_client_request *req;
- gchar *p, *hn, *hv;
+ struct rspamd_http_client_header *nh;
+ gchar *p;
gsize remain, old_len;
- GHashTableIter it;
+ GList *cur;
GString *input = NULL;
req = g_slice_alloc0 (sizeof (struct rspamd_client_request));
@@ -256,9 +257,12 @@ rspamd_client_command (struct rspamd_client_connection *conn,
}
/* Convert headers */
- g_hash_table_iter_init (&it, attrs);
- while (g_hash_table_iter_next (&it, (gpointer *)&hn, (gpointer *)&hv)) {
- rspamd_http_message_add_header (req->msg, hn, hv);
+ cur = attrs->head;
+ while (cur != NULL) {
+ nh = cur->data;
+
+ rspamd_http_message_add_header (req->msg, nh->name, nh->value);
+ cur = g_list_next (cur);
}
req->msg->url = rspamd_fstring_append (req->msg->url, "/", 1);
diff --git a/src/client/rspamdclient.h b/src/client/rspamdclient.h
index 85b51514b..570d37cc9 100644
--- a/src/client/rspamdclient.h
+++ b/src/client/rspamdclient.h
@@ -31,6 +31,11 @@
struct rspamd_client_connection;
struct rspamd_http_message;
+struct rspamd_http_client_header {
+ const gchar *name;
+ const gchar *value;
+};
+
/**
* Callback is called on client connection completed
* @param name name of server
@@ -76,7 +81,7 @@ struct rspamd_client_connection * rspamd_client_init (
gboolean rspamd_client_command (
struct rspamd_client_connection *conn,
const gchar *command,
- GHashTable *attrs,
+ GQueue *attrs,
FILE *in,
rspamd_client_callback cb,
gpointer ud,