Mercurial > prosody-modules
changeset 3001:1108a40c3118
mod_http_dir_listing2: Copy of mod_http_dir_listing
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Mon, 16 Apr 2018 21:03:13 +0200 (2018-04-16) |
parents | 02fc3b64cbb7 |
children | c91c9b87929e |
files | mod_http_dir_listing2/mod_http_dir_listing2.lua mod_http_dir_listing2/resources/folder.png mod_http_dir_listing2/resources/style.css mod_http_dir_listing2/resources/template.html mod_http_dir_listing2/resources/text-x-generic.png mod_http_dir_listing2/resources/user-home.png |
diffstat | 6 files changed, 88 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_http_dir_listing2/mod_http_dir_listing2.lua Mon Apr 16 21:03:13 2018 +0200 @@ -0,0 +1,64 @@ +-- Prosody IM +-- Copyright (C) 2012 Kim Alvefur +-- +-- This project is MIT/X11 licensed. Please see the +-- COPYING file in the source package for more information. +-- + +module:set_global(); +local server = require"net.http.server"; +local lfs = require "lfs"; +local stat = lfs.attributes; +local build_path = require"socket.url".build_path; +local base64_encode = require"util.encodings".base64.encode; +local tag = require"util.stanza".stanza; +local template = require"util.template"; + +local mime = module:shared("/*/http_files/mime"); + +local function get_resource(resource) + local fh = assert(module:load_resource(resource)); + local data = fh:read"*a"; + fh:close(); + return data; +end + +local dir_index_template = template(get_resource("resources/template.html")); +local style = get_resource("resources/style.css"):gsub("url%((.-)%)", function(url) + --module:log("debug", "Inlineing %s", url); + return "url(data:image/png;base64,"..base64_encode(get_resource("resources/"..url))..")"; +end); + +local function generate_directory_index(path, full_path) + local filelist = tag("ul", { class = "filelist" } ):text"\n"; + if path ~= "/" then + filelist:tag("li", { class = "parent directory" }) + :tag("a", { href = "..", rel = "up" }):text("Parent Directory"):up():up():text"\n" + end + local mime_map = mime.types; + for file in lfs.dir(full_path) do + if file:sub(1,1) ~= "." then + local attr = stat(full_path..file) or {}; + local path = { file }; + local file_ext = file:match"%.([^.]+)$"; + local type = attr.mode == "file" and file_ext and mime_map and mime_map[file_ext] or nil; + local class = table.concat({ attr.mode or "unknown", file_ext, type and type:match"^[^/]+" }, " "); + path.is_directory = attr.mode == "directory"; + filelist:tag("li", { class = class }) + :tag("a", { href = build_path(path), type = type }):text(file):up() + :up():text"\n"; + end + end + return "<!DOCTYPE html>\n"..tostring(dir_index_template.apply{ + path = path, + style = style, + filelist = filelist, + footer = "Prosody "..prosody.version, + }); +end + +module:hook_object_event(server, "directory-index", function (event) + local ok, data = pcall(generate_directory_index, event.path, event.full_path); + if ok then return data end + module:log("warn", data); +end);
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_http_dir_listing2/resources/style.css Mon Apr 16 21:03:13 2018 +0200 @@ -0,0 +1,10 @@ + +body{background-color:#eeeeec;font-family:sans-serif;} +h1{font-size:xx-large;} +a:link,a:visited{color:#2e3436;text-decoration:none;} +a:link:hover,a:visited:hover{color:#3465a4;} +.filelist{background-color:white;padding:1em;list-style-position:inside;-moz-column-width:20em;-webkit-column-width:20em;-ms-column-width:20em;column-width:20em;} +.file{list-style-image:url(text-x-generic.png);} +.directory{list-style-image:url(folder.png);} +.parent{list-style-image:url(user-home.png);} +footer{margin-top:1ex;font-size:smaller;color:#babdb6;}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_http_dir_listing2/resources/template.html Mon Apr 16 21:03:13 2018 +0200 @@ -0,0 +1,14 @@ +<html> + <head> + <title>Index of {path}</title> + <meta charset="utf-8"/> + <style>{style}</style> + </head> + <body> + <h1>Index of {path}</h1> + + {filelist} + + <footer>{footer}</footer> + </body> +</html>