lib/servel/app.rb in servel-0.14.0 vs lib/servel/app.rb in servel-0.15.0

- old
+ new

@@ -1,34 +1,48 @@ class Servel::App + UTF_8 = Encoding::UTF_8 + SCRIPT_NAME = Rack::SCRIPT_NAME + PATH_INFO = Rack::PATH_INFO + def initialize(root) @root = Pathname.new(root) @file_server = Rack::File.new(root.to_s) end def call(env) - url_root = env["SCRIPT_NAME"] - url_path = clean_url_path(env["PATH_INFO"]) + env[SCRIPT_NAME] = try_encode(env[SCRIPT_NAME]) + env[PATH_INFO] = try_encode(env[PATH_INFO]) - return redirect("#{url_root}/") if env["PATH_INFO"] == "" + url_root = env[SCRIPT_NAME] + url_path = clean_url_path(env[PATH_INFO]) + return redirect("#{url_root}/") if env[PATH_INFO] == "" + fs_path = @root + url_path[1..-1] return @file_server.call(env) if fs_path.file? - return redirect("#{url_root}#{url_path}/") unless env["PATH_INFO"].end_with?("/") + return redirect("#{url_root}#{url_path}/") unless env[PATH_INFO].end_with?("/") return [404, {}, []] unless fs_path.exist? request = Rack::Request.new(env) Servel::Index.new(url_root: url_root, url_path: url_path, fs_path: fs_path, params: request.params).render end def redirect(location) - [302, { "Location" => location }, []] + [302, { "Location" => Rack::Utils.escape_path(location) }, []] end def clean_url_path(path) url_path = Rack::Utils.unescape_path(path) raise unless Rack::Utils.valid_path?(url_path) Rack::Utils.clean_path_info(url_path) + end + + def try_encode(string) + return string if string.encoding == UTF_8 + string.encode(UTF_8) + rescue Encoding::UndefinedConversionError, Encoding::InvalidByteSequenceError + string end end \ No newline at end of file