# HG changeset patch # User Kim Alvefur # Date 1539519561 -7200 # Node ID 3456496d5218fcd3b8980a86cb12ae6c11053895 # Parent 8715961bfa13ff966c0af707ea40411341b97e54# Parent 09e7b0048ebe4a561e3c4e17136766f0c577846a Merge 0.10->trunk diff -r 8715961bfa13 -r 3456496d5218 plugins/mod_http.lua --- a/plugins/mod_http.lua Sat Oct 13 08:17:58 2018 +0100 +++ b/plugins/mod_http.lua Sun Oct 14 14:19:21 2018 +0200 @@ -21,8 +21,12 @@ server.set_option("body_size_limit", module:get_option_number("http_max_content_size")); server.set_option("buffer_size_limit", module:get_option_number("http_max_buffer_size")); -local function normalize_path(path) - if path:sub(-1,-1) == "/" then path = path:sub(1, -2); end +local function normalize_path(path, is_dir) + if is_dir then + if path:sub(-1,-1) ~= "/" then path = path.."/"; end + else + if path:sub(-1,-1) == "/" then path = path:sub(1, -2); end + end if path:sub(1,1) ~= "/" then path = "/"..path; end return path; end @@ -77,7 +81,7 @@ scheme = (external_url.scheme or service[1].service.name); host = (external_url.host or module:get_option_string("http_host", module.host)); port = tonumber(external_url.port) or port or 80; - path = normalize_path(external_url.path or "/").. + path = normalize_path(external_url.path or "/", true).. (get_base_path(module, app_name, default_path or "/"..app_name):sub(2)); } if ports_by_scheme[url.scheme] == url.port then url.port = nil end