* lib/webrick/server.rb (WEBrick::GenericServer#start_thread):

should log about all accepted socket. [ruby-core:03962]

* lib/webrick/accesslog.rb (WEBrick::AccessLog#setup_params):
  "%%" and "%u" are supported. [webricken:135]

* lib/webrick/httpservlet/filehandler.rb
  (WEBrick::HTTPServlet::FileHandler#check_filename):
  :NondisclosureName is acceptable if it is Enumerable.

* lib/webrick/config.rb (WEBrick::Config::FileHandler):
  default value of :NondisclosureName is [".ht*", "*~"].


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7566 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
gotoyuzo 2004-12-15 08:47:49 +00:00
Родитель 2edbb9d0f8
Коммит 52d91fa402
5 изменённых файлов: 47 добавлений и 13 удалений

Просмотреть файл

@ -1,3 +1,18 @@
Wed Dec 15 17:47:17 2004 GOTOU Yuuzou <gotoyuzo@notwork.org>
* lib/webrick/server.rb (WEBrick::GenericServer#start_thread):
should log about all accepted socket. [ruby-core:03962]
* lib/webrick/accesslog.rb (WEBrick::AccessLog#setup_params):
"%%" and "%u" are supported. [webricken:135]
* lib/webrick/httpservlet/filehandler.rb
(WEBrick::HTTPServlet::FileHandler#check_filename):
:NondisclosureName is acceptable if it is Enumerable.
* lib/webrick/config.rb (WEBrick::Config::FileHandler):
default value of :NondisclosureName is [".ht*", "*~"].
Wed Dec 15 15:31:02 2004 Yukihiro Matsumoto <matz@ruby-lang.org> Wed Dec 15 15:31:02 2004 Yukihiro Matsumoto <matz@ruby-lang.org>
* lib/set.rb (Set#==): [ruby-dev:25206] * lib/set.rb (Set#==): [ruby-dev:25206]

Просмотреть файл

@ -32,6 +32,7 @@ module WEBrick
params["i"] = req params["i"] = req
params["l"] = "-" params["l"] = "-"
params["m"] = req.request_method params["m"] = req.request_method
params["n"] = req.attributes
params["o"] = res params["o"] = res
params["p"] = req.port params["p"] = req.port
params["q"] = req.query_string params["q"] = req.query_string
@ -46,15 +47,17 @@ module WEBrick
end end
def format(format_string, params) def format(format_string, params)
format_string.gsub(/\%(?:\{(.*?)\})?>?([a-zA-Z])/){ format_string.gsub(/\%(?:\{(.*?)\})?>?([a-zA-Z%])/){
param, spec = $1, $2 param, spec = $1, $2
case spec[0] case spec[0]
when ?e, ?i, ?o when ?e, ?i, ?n, ?o
raise AccessLogError, raise AccessLogError,
"parameter is required for \"#{spec}\"" unless param "parameter is required for \"#{spec}\"" unless param
params[spec][param] || "-" params[spec][param] || "-"
when ?t when ?t
params[spec].strftime(param || CLF_TIME_FORMAT) params[spec].strftime(param || CLF_TIME_FORMAT)
when ?%
"%"
else else
params[spec] params[spec]
end end

Просмотреть файл

@ -65,7 +65,7 @@ module WEBrick
) )
FileHandler = { FileHandler = {
:NondisclosureName => ".ht*", :NondisclosureName => [".ht*", "*~"],
:FancyIndexing => false, :FancyIndexing => false,
:HandlerTable => {}, :HandlerTable => {},
:HandlerCallback => nil, :HandlerCallback => nil,

Просмотреть файл

@ -226,7 +226,7 @@ module WEBrick
path_info.unshift("") # dummy for checking @root dir path_info.unshift("") # dummy for checking @root dir
while base = path_info.first while base = path_info.first
check_filename(base) check_filename(req, res, base)
break if base == "/" break if base == "/"
break unless File.directory?(res.filename + base) break unless File.directory?(res.filename + base)
shift_path_info(req, res, path_info) shift_path_info(req, res, path_info)
@ -234,7 +234,7 @@ module WEBrick
end end
if base = path_info.first if base = path_info.first
check_filename(base) check_filename(req, res, base)
if base == "/" if base == "/"
if file = search_index_file(req, res) if file = search_index_file(req, res)
shift_path_info(req, res, path_info, file) shift_path_info(req, res, path_info, file)
@ -254,11 +254,13 @@ module WEBrick
return false return false
end end
def check_filename(name) def check_filename(req, res, name)
if File.fnmatch("/#{@options[:NondisclosureName]}", name) @options[:NondisclosureName].each{|pattern|
@logger.warn("the request refers nondisclosure name `#{name}'.") if File.fnmatch("/#{pattern}", name)
raise HTTPStatus::NotFound, "`#{req.path}' not found." @logger.warn("the request refers nondisclosure name `#{name}'.")
end raise HTTPStatus::NotFound, "`#{req.path}' not found."
end
}
end end
def shift_path_info(req, res, path_info, base=nil) def shift_path_info(req, res, path_info, base=nil)
@ -306,6 +308,15 @@ module WEBrick
end end
end end
def nondisclosure_name?(name)
@options[:NondisclosureName].each{|pattern|
if File.fnmatch(pattern, name)
return true
end
}
return false
end
def set_dir_list(req, res) def set_dir_list(req, res)
redirect_to_directory_uri(req, res) redirect_to_directory_uri(req, res)
unless @options[:FancyIndexing] unless @options[:FancyIndexing]
@ -314,7 +325,7 @@ module WEBrick
local_path = res.filename local_path = res.filename
list = Dir::entries(local_path).collect{|name| list = Dir::entries(local_path).collect{|name|
next if name == "." || name == ".." next if name == "." || name == ".."
next if File::fnmatch(@options[:NondisclosureName], name) next if nondisclosure_name?(name)
st = (File::stat(local_path + name) rescue nil) st = (File::stat(local_path + name) rescue nil)
if st.nil? if st.nil?
[ name, nil, -1 ] [ name, nil, -1 ]

Просмотреть файл

@ -147,8 +147,13 @@ module WEBrick
Thread.start{ Thread.start{
begin begin
Thread.current[:WEBrickSocket] = sock Thread.current[:WEBrickSocket] = sock
addr = sock.peeraddr begin
@logger.debug "accept: #{addr[3]}:#{addr[1]}" addr = sock.peeraddr
@logger.debug "accept: #{addr[3]}:#{addr[1]}"
rescue SocketError
@logger.debug "accept: <address unknown>"
raise
end
call_callback(:AcceptCallback, sock) call_callback(:AcceptCallback, sock)
block ? block.call(sock) : run(sock) block ? block.call(sock) : run(sock)
rescue Errno::ENOTCONN rescue Errno::ENOTCONN