diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-04-12 08:45:53 -0700 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-04-12 08:45:53 -0700 |
commit | e57df8f4f9dabecc4876e0e15bc082d7c4e15a70 (patch) | |
tree | 3ec3bb14cedb0fa3390f937b29bfbf5ea86b194c | |
parent | e4a490dee60978f7493e703cf5af1a64cf513b67 (diff) | |
download | rspamd-e57df8f4f9dabecc4876e0e15bc082d7c4e15a70.tar.gz rspamd-e57df8f4f9dabecc4876e0e15bc082d7c4e15a70.zip |
Improve files handling in http worker.
-rw-r--r-- | src/http.c | 55 |
1 files changed, 52 insertions, 3 deletions
diff --git a/src/http.c b/src/http.c index 39ce4924a..88946083e 100644 --- a/src/http.c +++ b/src/http.c @@ -44,10 +44,32 @@ struct rspamd_http_connection_private { gsize wr_total; }; +enum http_magic_type { + HTTP_MAGIC_PLAIN = 0, + HTTP_MAGIC_HTML, + HTTP_MAGIC_CSS, + HTTP_MAGIC_JS, + HTTP_MAGIC_PNG, + HTTP_MAGIC_JPG +}; + +static const struct _rspamd_http_magic { + const gchar *ext; + const gchar *ct; +} http_file_types[] = { + [HTTP_MAGIC_PLAIN] = { "txt", "text/plain" }, + [HTTP_MAGIC_HTML] = { "html", "text/html" }, + [HTTP_MAGIC_CSS] = { "css", "text/css" }, + [HTTP_MAGIC_JS] = { "js", "application/javascript" }, + [HTTP_MAGIC_PNG] = { "png", "image/png" }, + [HTTP_MAGIC_JPG] = { "jpg", "image/jpeg" }, +}; + static gchar *http_week[] = { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" }; static gchar *http_month[] = { "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" }; + #define HTTP_ERROR http_error_quark () GQuark http_error_quark (void) @@ -966,13 +988,34 @@ rspamd_http_router_error_handler (struct rspamd_http_connection *conn, GError *e } } +static const gchar * +rspamd_http_router_detect_ct (const gchar *path) +{ + const gchar *dot; + guint i; + + dot = strrchr (path, '.'); + if (dot == NULL) { + return http_file_types[HTTP_MAGIC_PLAIN].ct; + } + dot ++; + + for (i = 0; i < G_N_ELEMENTS (http_file_types); i ++) { + if (strcmp (http_file_types[i].ext, dot) == 0) { + return http_file_types[i].ct; + } + } + + return http_file_types[HTTP_MAGIC_PLAIN].ct; +} + static gboolean rspamd_http_router_try_file (struct rspamd_http_connection_entry *entry, struct rspamd_http_message *msg) { struct stat st; - int fd; - char filebuf[PATH_MAX], realbuf[PATH_MAX]; + gint fd; + gchar filebuf[PATH_MAX], realbuf[PATH_MAX]; struct rspamd_http_message *reply_msg; /* XXX: filter filename component only */ @@ -982,6 +1025,12 @@ rspamd_http_router_try_file (struct rspamd_http_connection_entry *entry, if (realpath (filebuf, realbuf) == NULL || lstat (realbuf, &st) == -1 || !S_ISREG (st.st_mode)) { + if (S_ISDIR (st.st_mode)) { + /* Try to append 'index.html' to the url */ + g_string_append_printf (msg->url, "%c%s", G_DIR_SEPARATOR, + "index.html"); + return rspamd_http_router_try_file (entry, msg); + } /* Skip everything suspicious */ return FALSE; } @@ -1010,7 +1059,7 @@ rspamd_http_router_try_file (struct rspamd_http_connection_entry *entry, /* XXX: detect content type */ rspamd_http_connection_write_message (entry->conn, reply_msg, NULL, - "text/plain", entry, entry->conn->fd, + rspamd_http_router_detect_ct (realbuf), entry, entry->conn->fd, entry->rt->ptv, entry->rt->ev_base); return TRUE; |