aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2012-12-11 23:21:25 +0100
committerKim Alvefur <zash@zash.se>2012-12-11 23:21:25 +0100
commite33b0e3602ed44b47bddc3122915eb7a5eef874c (patch)
tree25cf0e22f28addf40d5237e26d190d7f4278ac5e
parentddaa8006bc9ec70b6cf3ebf3da5f1249edf177ea (diff)
downloadprosody-e33b0e3602ed44b47bddc3122915eb7a5eef874c.tar.gz
prosody-e33b0e3602ed44b47bddc3122915eb7a5eef874c.zip
mod_http_files: Have mimetypes in a shared table. Get mimetypes from /etc/mime.types if exists.
-rw-r--r--plugins/mod_http_files.lua38
1 files changed, 28 insertions, 10 deletions
diff --git a/plugins/mod_http_files.lua b/plugins/mod_http_files.lua
index b049609e..f4246fd5 100644
--- a/plugins/mod_http_files.lua
+++ b/plugins/mod_http_files.lua
@@ -16,16 +16,34 @@ local stat = lfs.attributes;
local http_base = module:get_option_string("http_files_dir", module:get_option_string("http_path", "www_files"));
local dir_indices = module:get_option("http_files_index", { "index.html", "index.htm" });
--- TODO: Should we read this from /etc/mime.types if it exists? (startup time...?)
-local mime_map = {
- html = "text/html";
- htm = "text/html";
- xml = "text/xml";
- xsl = "text/xml";
- txt = "text/plain; charset=utf-8";
- js = "text/javascript";
- css = "text/css";
-};
+local mime_map = module:shared("mime").types;
+if not mime_map then
+ mime_map = {
+ html = "text/html", htm = "text/html",
+ xml = "application/xml",
+ txt = "text/plain",
+ css = "text/css",
+ js = "application/javascript",
+ png = "image/png",
+ gif = "image/gif",
+ jpeg = "image/jpeg", jpg = "image/jpeg",
+ svg = "image/svg+xml",
+ };
+ module:shared("mime").types = mime_map;
+
+ local mime_types, err = open(module:get_option_string("mime_types_file", "/etc/mime.types"),"r");
+ if mime_types then
+ local mime_data = mime_types:read("*a");
+ mime_types:close();
+ setmetatable(mime_map, {
+ __index = function(t, ext)
+ local typ = mime_data:match("\n(%S+)[^\n]*%s"..(ext:lower()).."%s") or "application/octet-stream";
+ t[ext] = typ;
+ return typ;
+ end
+ });
+ end
+end
local cache = setmetatable({}, { __mode = "kv" }); -- Let the garbage collector have it if it wants to.