From f2d2dfe9ca4a50bc88a5c3ff8242433f82ea7e75 Mon Sep 17 00:00:00 2001 From: shyouhei Date: Sun, 10 Jan 2010 10:30:06 +0000 Subject: merge revision(s) 26267: * lib/webrick/accesslog.rb : Escape needed. * lib/webrick/httpstatus.rb : ditto. * lib/webrick/httprequest.rb : ditto. * lib/webrick/httputils.rb : ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_7@26268 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 10 ++++++++++ lib/webrick/accesslog.rb | 12 ++++++++++-- lib/webrick/httprequest.rb | 6 +----- lib/webrick/httpstatus.rb | 31 ++++++++++++++++++------------- lib/webrick/httputils.rb | 4 ++-- version.h | 12 ++++++------ 6 files changed, 47 insertions(+), 28 deletions(-) diff --git a/ChangeLog b/ChangeLog index 76cb732f53..2e30630260 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,13 @@ +Sun Jan 10 19:00:31 2010 Nobuyoshi Nakada + + * lib/webrick/accesslog.rb : Escape needed. + + * lib/webrick/httpstatus.rb : ditto. + + * lib/webrick/httprequest.rb : ditto. + + * lib/webrick/httputils.rb : ditto. + Thu Dec 24 18:04:27 2009 Nobuyoshi Nakada * configure.in: default ac_cv_prog_CC to CC. diff --git a/lib/webrick/accesslog.rb b/lib/webrick/accesslog.rb index f97769545e..75a3a3e694 100644 --- a/lib/webrick/accesslog.rb +++ b/lib/webrick/accesslog.rb @@ -53,15 +53,23 @@ module WEBrick when ?e, ?i, ?n, ?o raise AccessLogError, "parameter is required for \"#{spec}\"" unless param - params[spec][param] || "-" + param = params[spec][param] ? escape(param) : "-" when ?t params[spec].strftime(param || CLF_TIME_FORMAT) when ?% "%" else - params[spec] + escape(params[spec].to_s) end } end + + def escape(data) + if data.tainted? + data.gsub(/[[:cntrl:]\\]+/) {$&.dump[1...-1]}.untaint + else + data + end + end end end diff --git a/lib/webrick/httprequest.rb b/lib/webrick/httprequest.rb index 4021259072..5bb470285f 100644 --- a/lib/webrick/httprequest.rb +++ b/lib/webrick/httprequest.rb @@ -242,11 +242,7 @@ module WEBrick @raw_header << line end end - begin - @header = HTTPUtils::parse_header(@raw_header) - rescue => ex - raise HTTPStatus::BadRequest, ex.message - end + @header = HTTPUtils::parse_header(@raw_header.join) end def parse_uri(str, scheme="http") diff --git a/lib/webrick/httpstatus.rb b/lib/webrick/httpstatus.rb index 0b22c992b3..032d14b8a3 100644 --- a/lib/webrick/httpstatus.rb +++ b/lib/webrick/httpstatus.rb @@ -12,7 +12,17 @@ module WEBrick module HTTPStatus - class Status < StandardError; end + class Status < StandardError + def initialize(message=self.class, *rest) + super(AccessLog.escape(message), *rest) + end + class << self + attr_reader :code, :reason_phrase + end + def code() self::class::code end + def reason_phrase() self::class::reason_phrase end + alias to_i code + end class Info < Status; end class Success < Status; end class Redirect < Status; end @@ -68,6 +78,7 @@ module WEBrick CodeToError = {} StatusMessage.each{|code, message| + message.freeze var_name = message.gsub(/[ \-]/,'_').upcase err_name = message.gsub(/[ \-]/,'') @@ -79,18 +90,12 @@ module WEBrick when 500...600; parent = ServerError end - eval %- - RC_#{var_name} = #{code} - class #{err_name} < #{parent} - def self.code() RC_#{var_name} end - def self.reason_phrase() StatusMessage[code] end - def code() self::class::code end - def reason_phrase() self::class::reason_phrase end - alias to_i code - end - - - - CodeToError[code] = const_get(err_name) + const_set("RC_#{var_name}", code) + err_class = Class.new(parent) + err_class.instance_variable_set(:@code, code) + err_class.instance_variable_set(:@reason_phrase, message) + const_set(err_name, err_class) + CodeToError[code] = err_class } def reason_phrase(code) diff --git a/lib/webrick/httputils.rb b/lib/webrick/httputils.rb index 976d3e915e..a0cf4c8ff8 100644 --- a/lib/webrick/httputils.rb +++ b/lib/webrick/httputils.rb @@ -128,11 +128,11 @@ module WEBrick when /^\s+(.*?)\s*\z/om value = $1 unless field - raise "bad header '#{line.inspect}'." + raise HTTPStatus::BadRequest, "bad header '#{line}'." end header[field][-1] << " " << value else - raise "bad header '#{line.inspect}'." + raise HTTPStatus::BadRequest, "bad header '#{line}'." end } header.each{|key, values| diff --git a/version.h b/version.h index 809e734483..e2c372c202 100644 --- a/version.h +++ b/version.h @@ -1,15 +1,15 @@ #define RUBY_VERSION "1.8.7" -#define RUBY_RELEASE_DATE "2009-12-24" +#define RUBY_RELEASE_DATE "2010-01-10" #define RUBY_VERSION_CODE 187 -#define RUBY_RELEASE_CODE 20091224 -#define RUBY_PATCHLEVEL 248 +#define RUBY_RELEASE_CODE 20100110 +#define RUBY_PATCHLEVEL 249 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 8 #define RUBY_VERSION_TEENY 7 -#define RUBY_RELEASE_YEAR 2009 -#define RUBY_RELEASE_MONTH 12 -#define RUBY_RELEASE_DAY 24 +#define RUBY_RELEASE_YEAR 2010 +#define RUBY_RELEASE_MONTH 1 +#define RUBY_RELEASE_DAY 10 #ifdef RUBY_EXTERN RUBY_EXTERN const char ruby_version[]; -- cgit v1.2.3