sinatra-request-logger 0.1.0 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,4 +1,4 @@
1
1
  ---
2
2
  :major: 0
3
- :minor: 1
3
+ :minor: 2
4
4
  :patch: 0
@@ -1,56 +1,48 @@
1
1
  module Sinatra
2
2
  module RequestLogger
3
3
  def self.registered(app)
4
- app.use RequestLogger, app.logger
5
- app.set :show_exceptions, false
6
- app.error do
7
- settings.logger.info("#{env['sinatra.error'].class} (#{env['sinatra.error'].message})")
8
- settings.logger.info(env['sinatra.error'].backtrace.join("\n"))
9
- end
4
+ app.set :proxy_logger, ProxyLogger.new(app.logger)
5
+ app.use Rack::CommonLogger, app.proxy_logger
6
+ app.use ErrorLogger, app.proxy_logger
10
7
  end
11
8
 
12
- class RequestLogger
13
- # Common Log Format: http://httpd.apache.org/docs/1.3/logs.html#common
14
- # lilith.local - - [07/Aug/2006 23:58:02] "GET / HTTP/1.1" 500 -
15
- # %{%s - %s [%s] "%s %s%s %s" %d %s\n} %
16
- FORMAT = %{%s - %s [%s] "%s %s%s %s" %d %s %0.4f}
17
-
18
- def initialize(app, logger=nil)
19
- @app = app
9
+ class ProxyLogger
10
+ def initialize(logger)
20
11
  @logger = logger
21
12
  end
22
13
 
23
- def call(env)
24
- began_at = Time.now
25
- status, header, body = @app.call(env)
26
- header = Rack::Utils::HeaderHash.new(header)
27
- log(env, status, header, began_at)
28
- [status, header, body]
14
+ def write(msg)
15
+ @logger.info(msg)
16
+ end
17
+
18
+ def flush
19
+ #nothing
29
20
  end
30
21
 
31
- private
22
+ def puts(msg)
23
+ if msg.is_a?(Array)
24
+ @logger.info(msg.map(&:chomp).join("\n"))
25
+ elsif msg.is_a?(String)
26
+ @logger.info(msg.chomp)
27
+ else
28
+ @logger.info(msg)
29
+ end
30
+ end
32
31
 
33
- def log(env, status, header, began_at)
34
- now = Time.now
35
- length = extract_content_length(header)
32
+ def method_missing(method, *args)
33
+ @logger.send(method, *args)
34
+ end
35
+ end
36
36
 
37
- logger = @logger || env['rack.errors']
38
- logger.info FORMAT % [
39
- env['HTTP_X_FORWARDED_FOR'] || env["REMOTE_ADDR"] || "-",
40
- env["REMOTE_USER"] || "-",
41
- now.strftime("%d/%b/%Y %H:%M:%S"),
42
- env["REQUEST_METHOD"],
43
- env["PATH_INFO"],
44
- env["QUERY_STRING"].empty? ? "" : "?"+env["QUERY_STRING"],
45
- env["HTTP_VERSION"],
46
- status.to_s[0..3],
47
- length,
48
- now - began_at ]
37
+ class ErrorLogger
38
+ def initialize(app, logger)
39
+ @app = app
40
+ @logger = logger
49
41
  end
50
42
 
51
- def extract_content_length(headers)
52
- value = headers['Content-Length'] or return '-'
53
- value.to_s == '0' ? '-' : value
43
+ def call(env)
44
+ env['rack.errors'] = @logger
45
+ @app.call(env)
54
46
  end
55
47
  end
56
48
  end
@@ -0,0 +1,54 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run the gemspec command
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = %q{sinatra-request-logger}
8
+ s.version = "0.2.0"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Cyril Mougel"]
12
+ s.date = %q{2010-05-03}
13
+ s.description = %q{Log request and error on Logger send it by settings}
14
+ s.email = %q{cyril@yeastymobs.com}
15
+ s.extra_rdoc_files = [
16
+ "LICENSE",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ ".gitignore",
22
+ "LICENSE",
23
+ "README.rdoc",
24
+ "Rakefile",
25
+ "VERSION.yml",
26
+ "lib/sinatra/request-logger.rb",
27
+ "sinatra-request-logger.gemspec",
28
+ "test/helper.rb",
29
+ "test/test_sinatra-logger.rb"
30
+ ]
31
+ s.homepage = %q{http://github.com/shingara/sinatra-request-logger}
32
+ s.rdoc_options = ["--charset=UTF-8"]
33
+ s.require_paths = ["lib"]
34
+ s.rubygems_version = %q{1.3.6}
35
+ s.summary = %q{Log all request and error on Logger}
36
+ s.test_files = [
37
+ "test/helper.rb",
38
+ "test/test_sinatra-logger.rb"
39
+ ]
40
+
41
+ if s.respond_to? :specification_version then
42
+ current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
43
+ s.specification_version = 3
44
+
45
+ if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
46
+ s.add_runtime_dependency(%q<sinatra>, [">= 1.0.0"])
47
+ else
48
+ s.add_dependency(%q<sinatra>, [">= 1.0.0"])
49
+ end
50
+ else
51
+ s.add_dependency(%q<sinatra>, [">= 1.0.0"])
52
+ end
53
+ end
54
+
metadata CHANGED
@@ -4,9 +4,9 @@ version: !ruby/object:Gem::Version
4
4
  prerelease: false
5
5
  segments:
6
6
  - 0
7
- - 1
7
+ - 2
8
8
  - 0
9
- version: 0.1.0
9
+ version: 0.2.0
10
10
  platform: ruby
11
11
  authors:
12
12
  - Cyril Mougel
@@ -48,6 +48,7 @@ files:
48
48
  - Rakefile
49
49
  - VERSION.yml
50
50
  - lib/sinatra/request-logger.rb
51
+ - sinatra-request-logger.gemspec
51
52
  - test/helper.rb
52
53
  - test/test_sinatra-logger.rb
53
54
  has_rdoc: true