rack-bug 0.2.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +3 -0
- data/History.txt +0 -0
- data/MIT-LICENSE.txt +19 -0
- data/README.rdoc +29 -0
- data/Rakefile +36 -0
- data/VERSION +1 -0
- data/lib/rack/bug.rb +43 -0
- data/lib/rack/bug/options.rb +89 -0
- data/lib/rack/bug/panel.rb +50 -0
- data/lib/rack/bug/panel_app.rb +33 -0
- data/lib/rack/bug/panels/active_record_panel.rb +45 -0
- data/lib/rack/bug/panels/active_record_panel/activerecord_extensions.rb +18 -0
- data/lib/rack/bug/panels/cache_panel.rb +50 -0
- data/lib/rack/bug/panels/cache_panel/memcache_extension.rb +129 -0
- data/lib/rack/bug/panels/cache_panel/panel_app.rb +48 -0
- data/lib/rack/bug/panels/cache_panel/stats.rb +97 -0
- data/lib/rack/bug/panels/log_panel.rb +39 -0
- data/lib/rack/bug/panels/log_panel/rails_extension.rb +11 -0
- data/lib/rack/bug/panels/memory_panel.rb +27 -0
- data/lib/rack/bug/panels/rails_info_panel.rb +23 -0
- data/lib/rack/bug/panels/redis_panel.rb +44 -0
- data/lib/rack/bug/panels/redis_panel/redis_extension.rb +14 -0
- data/lib/rack/bug/panels/redis_panel/stats.rb +48 -0
- data/lib/rack/bug/panels/request_variables_panel.rb +25 -0
- data/lib/rack/bug/panels/sql_panel.rb +55 -0
- data/lib/rack/bug/panels/sql_panel/panel_app.rb +37 -0
- data/lib/rack/bug/panels/sql_panel/query.rb +73 -0
- data/lib/rack/bug/panels/sql_panel/sql_extension.rb +11 -0
- data/lib/rack/bug/panels/templates_panel.rb +44 -0
- data/lib/rack/bug/panels/templates_panel/actionview_extension.rb +12 -0
- data/lib/rack/bug/panels/templates_panel/rendering.rb +67 -0
- data/lib/rack/bug/panels/templates_panel/trace.rb +34 -0
- data/lib/rack/bug/panels/timer_panel.rb +40 -0
- data/lib/rack/bug/params_signature.rb +65 -0
- data/lib/rack/bug/public/__rack_bug__/bookmarklet.html +10 -0
- data/lib/rack/bug/public/__rack_bug__/bookmarklet.js +215 -0
- data/lib/rack/bug/public/__rack_bug__/bug.css +211 -0
- data/lib/rack/bug/public/__rack_bug__/bug.js +84 -0
- data/lib/rack/bug/public/__rack_bug__/jquery-1.3.2.js +4376 -0
- data/lib/rack/bug/public/__rack_bug__/jquery.tablesorter.min.js +1 -0
- data/lib/rack/bug/public/__rack_bug__/spinner.gif +0 -0
- data/lib/rack/bug/render.rb +66 -0
- data/lib/rack/bug/toolbar.rb +137 -0
- data/lib/rack/bug/views/error.html.erb +16 -0
- data/lib/rack/bug/views/panels/active_record.html.erb +17 -0
- data/lib/rack/bug/views/panels/cache.html.erb +93 -0
- data/lib/rack/bug/views/panels/execute_sql.html.erb +32 -0
- data/lib/rack/bug/views/panels/explain_sql.html.erb +32 -0
- data/lib/rack/bug/views/panels/log.html.erb +23 -0
- data/lib/rack/bug/views/panels/profile_sql.html.erb +32 -0
- data/lib/rack/bug/views/panels/rails_info.html.erb +19 -0
- data/lib/rack/bug/views/panels/redis.html.erb +32 -0
- data/lib/rack/bug/views/panels/request_variables.html.erb +107 -0
- data/lib/rack/bug/views/panels/sql.html.erb +43 -0
- data/lib/rack/bug/views/panels/templates.html.erb +7 -0
- data/lib/rack/bug/views/panels/timer.html.erb +19 -0
- data/lib/rack/bug/views/panels/view_cache.html.erb +19 -0
- data/lib/rack/bug/views/redirect.html.erb +16 -0
- data/lib/rack/bug/views/toolbar.html.erb +42 -0
- data/rack-bug.gemspec +126 -0
- data/spec/fixtures/config.ru +8 -0
- data/spec/fixtures/dummy_panel.rb +2 -0
- data/spec/fixtures/sample_app.rb +29 -0
- data/spec/rack/bug/panels/active_record_panel_spec.rb +30 -0
- data/spec/rack/bug/panels/cache_panel_spec.rb +159 -0
- data/spec/rack/bug/panels/log_panel_spec.rb +25 -0
- data/spec/rack/bug/panels/memory_panel_spec.rb +21 -0
- data/spec/rack/bug/panels/rails_info_panel_spec.rb +25 -0
- data/spec/rack/bug/panels/redis_panel_spec.rb +57 -0
- data/spec/rack/bug/panels/sql_panel_spec.rb +136 -0
- data/spec/rack/bug/panels/templates_panel_spec.rb +71 -0
- data/spec/rack/bug/panels/timer_panel_spec.rb +38 -0
- data/spec/rack/toolbar_spec.rb +100 -0
- data/spec/rcov.opts +1 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +70 -0
- metadata +143 -0
data/.gitignore
ADDED
data/History.txt
ADDED
File without changes
|
data/MIT-LICENSE.txt
ADDED
@@ -0,0 +1,19 @@
|
|
1
|
+
Copyright (c) 2009 Bryan Helmkamp
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
4
|
+
of this software and associated documentation files (the "Software"), to deal
|
5
|
+
in the Software without restriction, including without limitation the rights
|
6
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
7
|
+
copies of the Software, and to permit persons to whom the Software is
|
8
|
+
furnished to do so, subject to the following conditions:
|
9
|
+
|
10
|
+
The above copyright notice and this permission notice shall be included in
|
11
|
+
all copies or substantial portions of the Software.
|
12
|
+
|
13
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
14
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
15
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
16
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
17
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
18
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
19
|
+
THE SOFTWARE.
|
data/README.rdoc
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
Usage:
|
2
|
+
|
3
|
+
script/plugin install git://github.com/brynary/rack-bug.git
|
4
|
+
|
5
|
+
# config/environments/development.rb
|
6
|
+
config.middleware.use "Rack::Bug"
|
7
|
+
|
8
|
+
# add bookmarklet to browser
|
9
|
+
open http://RAILS_APP/__rack_bug__/bookmarklet.html
|
10
|
+
|
11
|
+
Notes:
|
12
|
+
|
13
|
+
To use rack-bug with hoptoad, you need to stub hoptoad from trying to serialize the environment variables
|
14
|
+
that rack-bug uses like so:
|
15
|
+
|
16
|
+
HoptoadNotifier.configure do |config|
|
17
|
+
config.environment_filters << 'rack-bug.*'
|
18
|
+
end
|
19
|
+
|
20
|
+
|
21
|
+
Thanks to:
|
22
|
+
|
23
|
+
Django debug toolbar
|
24
|
+
Rails footnotes
|
25
|
+
Rack's ShowException middleware
|
26
|
+
Oink
|
27
|
+
Rack::Cache
|
28
|
+
|
29
|
+
|
data/Rakefile
ADDED
@@ -0,0 +1,36 @@
|
|
1
|
+
require "rubygems"
|
2
|
+
require "spec/rake/spectask"
|
3
|
+
|
4
|
+
$LOAD_PATH.unshift File.dirname(__FILE__) + '/lib'
|
5
|
+
require "rack/bug"
|
6
|
+
|
7
|
+
begin
|
8
|
+
require 'jeweler'
|
9
|
+
Jeweler::Tasks.new do |s|
|
10
|
+
s.name = "rack-bug"
|
11
|
+
s.author = "Bryan Helmkamp"
|
12
|
+
s.email = "bryan" + "@" + "brynary.com"
|
13
|
+
s.homepage = "http://github.com/brynary/rack-bug"
|
14
|
+
s.summary = "Debugging toolbar for Rack applications implemented as middleware"
|
15
|
+
# s.description = "TODO"
|
16
|
+
s.extra_rdoc_files = %w(README.rdoc MIT-LICENSE.txt)
|
17
|
+
end
|
18
|
+
rescue LoadError
|
19
|
+
puts "Jeweler not available. Install it with: gem install jeweler"
|
20
|
+
end
|
21
|
+
|
22
|
+
Spec::Rake::SpecTask.new do |t|
|
23
|
+
t.spec_opts = ['--options', "\"#{File.dirname(__FILE__)}/spec/spec.opts\""]
|
24
|
+
end
|
25
|
+
|
26
|
+
desc "Run all specs in spec directory with RCov"
|
27
|
+
Spec::Rake::SpecTask.new(:rcov) do |t|
|
28
|
+
t.spec_opts = ['--options', "\"#{File.dirname(__FILE__)}/spec/spec.opts\""]
|
29
|
+
t.rcov = true
|
30
|
+
t.rcov_opts = lambda do
|
31
|
+
IO.readlines(File.dirname(__FILE__) + "/spec/rcov.opts").map {|l| l.chomp.split " "}.flatten
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
desc "Run the specs"
|
36
|
+
task :default => :spec
|
data/VERSION
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
0.2.1
|
data/lib/rack/bug.rb
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
require "rack"
|
2
|
+
|
3
|
+
module Rack::Bug
|
4
|
+
autoload :Options, "rack/bug/options"
|
5
|
+
autoload :Panel, "rack/bug/panel"
|
6
|
+
autoload :PanelApp, "rack/bug/panel_app"
|
7
|
+
autoload :ParamsSignature, "rack/bug/params_signature"
|
8
|
+
autoload :Render, "rack/bug/render"
|
9
|
+
autoload :Toolbar, "rack/bug/toolbar"
|
10
|
+
|
11
|
+
# Panels
|
12
|
+
autoload :ActiveRecordPanel, "rack/bug/panels/active_record_panel"
|
13
|
+
autoload :CachePanel, "rack/bug/panels/cache_panel"
|
14
|
+
autoload :LogPanel, "rack/bug/panels/log_panel"
|
15
|
+
autoload :MemoryPanel, "rack/bug/panels/memory_panel"
|
16
|
+
autoload :RailsInfoPanel, "rack/bug/panels/rails_info_panel"
|
17
|
+
autoload :RedisPanel, "rack/bug/panels/redis_panel"
|
18
|
+
autoload :RequestVariablesPanel, "rack/bug/panels/request_variables_panel"
|
19
|
+
autoload :SQLPanel, "rack/bug/panels/sql_panel"
|
20
|
+
autoload :TemplatesPanel, "rack/bug/panels/templates_panel"
|
21
|
+
autoload :TimerPanel, "rack/bug/panels/timer_panel"
|
22
|
+
|
23
|
+
VERSION = File.read(File.join(File.dirname(__FILE__), "..", "..", "VERSION")).strip
|
24
|
+
|
25
|
+
class SecurityError < StandardError
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.enable
|
29
|
+
Thread.current["rack-bug.enabled"] = true
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.disable
|
33
|
+
Thread.current["rack-bug.enabled"] = false
|
34
|
+
end
|
35
|
+
|
36
|
+
def self.enabled?
|
37
|
+
Thread.current["rack-bug.enabled"] == true
|
38
|
+
end
|
39
|
+
|
40
|
+
def self.new(*args, &block)
|
41
|
+
Toolbar.new(*args, &block)
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
module Rack::Bug
|
2
|
+
|
3
|
+
module Options
|
4
|
+
class << self
|
5
|
+
private
|
6
|
+
def option_accessor(key)
|
7
|
+
define_method(key) { || read_option(key) }
|
8
|
+
define_method("#{key}=") { |value| write_option(key, value) }
|
9
|
+
define_method("#{key}?") { || !! read_option(key) }
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
option_accessor :secret_key
|
14
|
+
option_accessor :ip_masks
|
15
|
+
option_accessor :password
|
16
|
+
option_accessor :panel_classes
|
17
|
+
option_accessor :intercept_redirects
|
18
|
+
|
19
|
+
# The underlying options Hash. During initialization (or outside of a
|
20
|
+
# request), this is a default values Hash. During a request, this is the
|
21
|
+
# Rack environment Hash. The default values Hash is merged in underneath
|
22
|
+
# the Rack environment before each request is processed.
|
23
|
+
def options
|
24
|
+
@env || @default_options
|
25
|
+
end
|
26
|
+
|
27
|
+
# Set multiple options.
|
28
|
+
def options=(hash={})
|
29
|
+
hash.each { |key,value| write_option(key, value) }
|
30
|
+
end
|
31
|
+
|
32
|
+
# Set an option. When +option+ is a Symbol, it is set in the Rack
|
33
|
+
# Environment as "rack-cache.option". When +option+ is a String, it
|
34
|
+
# exactly as specified. The +option+ argument may also be a Hash in
|
35
|
+
# which case each key/value pair is merged into the environment as if
|
36
|
+
# the #set method were called on each.
|
37
|
+
def set(option, value=self, &block)
|
38
|
+
if block_given?
|
39
|
+
write_option option, block
|
40
|
+
elsif value == self
|
41
|
+
self.options = option.to_hash
|
42
|
+
else
|
43
|
+
write_option option, value
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
private
|
48
|
+
|
49
|
+
def read_option(key)
|
50
|
+
options[option_name(key)]
|
51
|
+
end
|
52
|
+
|
53
|
+
def write_option(key, value)
|
54
|
+
options[option_name(key)] = value
|
55
|
+
end
|
56
|
+
|
57
|
+
def option_name(key)
|
58
|
+
case key
|
59
|
+
when Symbol ; "rack-bug.#{key}"
|
60
|
+
when String ; key
|
61
|
+
else raise ArgumentError
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
def initialize_options(options={})
|
66
|
+
@default_options = {
|
67
|
+
'rack-bug.ip_masks' => [IPAddr.new("127.0.0.1")],
|
68
|
+
'rack-bug.password' => nil,
|
69
|
+
'rack-bug.verbose' => nil,
|
70
|
+
'rack-bug.secret_key' => nil,
|
71
|
+
'rack-bug.intercept_redirects' => false,
|
72
|
+
'rack-bug.panels' => [],
|
73
|
+
'rack-bug.panel_classes' => [
|
74
|
+
RailsInfoPanel,
|
75
|
+
TimerPanel,
|
76
|
+
RequestVariablesPanel,
|
77
|
+
SQLPanel,
|
78
|
+
ActiveRecordPanel,
|
79
|
+
CachePanel,
|
80
|
+
TemplatesPanel,
|
81
|
+
LogPanel,
|
82
|
+
MemoryPanel
|
83
|
+
]
|
84
|
+
}
|
85
|
+
self.options = options
|
86
|
+
end
|
87
|
+
|
88
|
+
end
|
89
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
require "erb"
|
2
|
+
|
3
|
+
module Rack
|
4
|
+
module Bug
|
5
|
+
|
6
|
+
# Panels are also Rack middleware
|
7
|
+
class Panel
|
8
|
+
include Render
|
9
|
+
include ERB::Util
|
10
|
+
|
11
|
+
attr_reader :request
|
12
|
+
|
13
|
+
def initialize(app)
|
14
|
+
if panel_app
|
15
|
+
@app = Rack::Cascade.new([panel_app, app])
|
16
|
+
else
|
17
|
+
@app = app
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
def call(env)
|
22
|
+
before(env)
|
23
|
+
status, headers, body = @app.call(env)
|
24
|
+
@request = Request.new(env)
|
25
|
+
after(env, status, headers, body)
|
26
|
+
env["rack-bug.panels"] << self
|
27
|
+
return [status, headers, body]
|
28
|
+
end
|
29
|
+
|
30
|
+
def panel_app
|
31
|
+
nil
|
32
|
+
end
|
33
|
+
|
34
|
+
def has_content?
|
35
|
+
true
|
36
|
+
end
|
37
|
+
|
38
|
+
def before(env)
|
39
|
+
end
|
40
|
+
|
41
|
+
def after(env, status, headers, body)
|
42
|
+
end
|
43
|
+
|
44
|
+
def render(template)
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
module Rack
|
2
|
+
module Bug
|
3
|
+
|
4
|
+
class PanelApp
|
5
|
+
include Rack::Bug::Render
|
6
|
+
|
7
|
+
attr_reader :request
|
8
|
+
|
9
|
+
def call(env)
|
10
|
+
@request = Rack::Request.new(env)
|
11
|
+
dispatch
|
12
|
+
end
|
13
|
+
|
14
|
+
def render_template(*args)
|
15
|
+
Rack::Response.new([super]).to_a
|
16
|
+
end
|
17
|
+
|
18
|
+
def params
|
19
|
+
@request.GET
|
20
|
+
end
|
21
|
+
|
22
|
+
def not_found
|
23
|
+
[404, {}, []]
|
24
|
+
end
|
25
|
+
|
26
|
+
def validate_params
|
27
|
+
ParamsSignature.new(request).validate!
|
28
|
+
end
|
29
|
+
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require "rack/bug/panels/active_record_panel/activerecord_extensions"
|
2
|
+
|
3
|
+
module Rack
|
4
|
+
module Bug
|
5
|
+
|
6
|
+
class ActiveRecordPanel < Panel
|
7
|
+
|
8
|
+
def self.record(class_name)
|
9
|
+
return unless Rack::Bug.enabled?
|
10
|
+
records[class_name] += 1
|
11
|
+
end
|
12
|
+
|
13
|
+
def self.reset
|
14
|
+
Thread.current["rack.bug.active_records"] = Hash.new { 0 }
|
15
|
+
end
|
16
|
+
|
17
|
+
def self.records
|
18
|
+
Thread.current["rack.bug.active_records"] ||= Hash.new { 0 }
|
19
|
+
end
|
20
|
+
|
21
|
+
def self.total
|
22
|
+
records.inject(0) do |memo, (key, value)|
|
23
|
+
memo + value
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def name
|
28
|
+
"active_record"
|
29
|
+
end
|
30
|
+
|
31
|
+
def heading
|
32
|
+
"#{self.class.total} AR Objects"
|
33
|
+
end
|
34
|
+
|
35
|
+
def content
|
36
|
+
records = self.class.records.to_a.sort_by { |key, value| value }.reverse
|
37
|
+
result = render_template "panels/active_record", :records => records
|
38
|
+
self.class.reset
|
39
|
+
result
|
40
|
+
end
|
41
|
+
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
if defined?(ActiveRecord)
|
2
|
+
ActiveRecord::Base.class_eval do
|
3
|
+
|
4
|
+
if instance_methods.include?("after_initialize")
|
5
|
+
def after_initialize_with_rack_bug
|
6
|
+
Rack::Bug::ActiveRecordPanel.record(self.class.base_class.name)
|
7
|
+
after_initialize_without_rack_bug
|
8
|
+
end
|
9
|
+
|
10
|
+
alias_method_chain :after_initialize, :rack_bug
|
11
|
+
else
|
12
|
+
def after_initialize
|
13
|
+
Rack::Bug::ActiveRecordPanel.record(self.class.base_class.name)
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
require "rack/bug/panels/cache_panel/memcache_extension"
|
2
|
+
|
3
|
+
module Rack
|
4
|
+
module Bug
|
5
|
+
|
6
|
+
class CachePanel < Panel
|
7
|
+
autoload :PanelApp, "rack/bug/panels/cache_panel/panel_app"
|
8
|
+
autoload :Stats, "rack/bug/panels/cache_panel/stats"
|
9
|
+
|
10
|
+
def self.record(method, *keys, &block)
|
11
|
+
return block.call unless Rack::Bug.enabled?
|
12
|
+
|
13
|
+
start_time = Time.now
|
14
|
+
result = block.call
|
15
|
+
total_time = Time.now - start_time
|
16
|
+
hit = result.nil? ? false : true
|
17
|
+
stats.record_call(method, total_time * 1_000, hit, *keys)
|
18
|
+
return result
|
19
|
+
end
|
20
|
+
|
21
|
+
def self.reset
|
22
|
+
Thread.current["rack.bug.cache"] = Stats.new
|
23
|
+
end
|
24
|
+
|
25
|
+
def self.stats
|
26
|
+
Thread.current["rack.bug.cache"] ||= Stats.new
|
27
|
+
end
|
28
|
+
|
29
|
+
def panel_app
|
30
|
+
PanelApp.new
|
31
|
+
end
|
32
|
+
|
33
|
+
def name
|
34
|
+
"cache"
|
35
|
+
end
|
36
|
+
|
37
|
+
def heading
|
38
|
+
"Cache: %.2fms (#{self.class.stats.queries.size} calls)" % self.class.stats.time
|
39
|
+
end
|
40
|
+
|
41
|
+
def content
|
42
|
+
result = render_template "panels/cache", :stats => self.class.stats
|
43
|
+
self.class.reset
|
44
|
+
return result
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,129 @@
|
|
1
|
+
if defined?(Memcached)
|
2
|
+
Memcached.class_eval do
|
3
|
+
|
4
|
+
def set_with_rack_bug(key, value, timeout=0, marshal=true)
|
5
|
+
Rack::Bug::CachePanel.record(:set, key) do
|
6
|
+
set_without_rack_bug(key, value, timeout, marshal)
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
def add_with_rack_bug(key, value, timeout=0, marshal=true)
|
11
|
+
Rack::Bug::CachePanel.record(:add, key) do
|
12
|
+
add_without_rack_bug(key, value, timeout, marshal)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
def increment_with_rack_bug(key, offset=1)
|
17
|
+
Rack::Bug::CachePanel.record(:incr, key) do
|
18
|
+
increment_without_rack_bug(key, offset)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def decrement_with_rack_bug(key, offset=1)
|
23
|
+
Rack::Bug::CachePanel.record(:decr, key) do
|
24
|
+
decrement_without_rack_bug(key, offset)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def replace_with_rack_bug(key, value, timeout=0, marshal=true)
|
29
|
+
Rack::Bug::CachePanel.record(:replace, key) do
|
30
|
+
replace_without_rack_bug(key, value, timeout, marshal)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def append_with_rack_bug(key, value)
|
35
|
+
Rack::Bug::CachePanel.record(:append, key) do
|
36
|
+
append_without_rack_bug(key, value)
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def prepend_with_rack_bug(key, value)
|
41
|
+
Rack::Bug::CachePanel.record(:prepend, key) do
|
42
|
+
prepend_without_rack_bug(key, value)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def delete_with_rack_bug(key)
|
47
|
+
Rack::Bug::CachePanel.record(:delete, key) do
|
48
|
+
delete_without_rack_bug(key)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def get_with_rack_bug(keys, marshal=true)
|
53
|
+
if keys.is_a? Array
|
54
|
+
Rack::Bug::CachePanel.record(:get_multi, *keys) do
|
55
|
+
get_without_rack_bug(keys, marshal)
|
56
|
+
end
|
57
|
+
else
|
58
|
+
Rack::Bug::CachePanel.record(:get, keys) do
|
59
|
+
get_without_rack_bug(keys, marshal)
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
alias_method_chain :decrement, :rack_bug
|
65
|
+
alias_method_chain :get, :rack_bug
|
66
|
+
alias_method_chain :increment, :rack_bug
|
67
|
+
alias_method_chain :set, :rack_bug
|
68
|
+
alias_method_chain :add, :rack_bug
|
69
|
+
alias_method_chain :replace, :rack_bug
|
70
|
+
alias_method_chain :delete, :rack_bug
|
71
|
+
alias_method_chain :prepend, :rack_bug
|
72
|
+
alias_method_chain :append, :rack_bug
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
if defined?(MemCache)
|
77
|
+
MemCache.class_eval do
|
78
|
+
|
79
|
+
def decr_with_rack_bug(key, amount = 1)
|
80
|
+
Rack::Bug::CachePanel.record(:decr, key) do
|
81
|
+
decr_without_rack_bug(key, amount)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
def get_with_rack_bug(key, raw = false)
|
86
|
+
Rack::Bug::CachePanel.record(:get, key) do
|
87
|
+
get_without_rack_bug(key, raw)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
def get_multi_with_rack_bug(*keys)
|
92
|
+
Rack::Bug::CachePanel.record(:get_multi, *keys) do
|
93
|
+
get_multi_without_rack_bug(*keys)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
def incr_with_rack_bug(key, amount = 1)
|
98
|
+
Rack::Bug::CachePanel.record(:incr, key) do
|
99
|
+
incr_without_rack_bug(key, amount)
|
100
|
+
end
|
101
|
+
end
|
102
|
+
|
103
|
+
def set_with_rack_bug(key, value, expiry = 0, raw = false)
|
104
|
+
Rack::Bug::CachePanel.record(:set, key) do
|
105
|
+
set_without_rack_bug(key, value, expiry, raw)
|
106
|
+
end
|
107
|
+
end
|
108
|
+
|
109
|
+
def add_with_rack_bug(key, value, expiry = 0, raw = false)
|
110
|
+
Rack::Bug::CachePanel.record(:add, key) do
|
111
|
+
add_without_rack_bug(key, value, expiry, raw)
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
def delete_with_rack_bug(key, expiry = 0)
|
116
|
+
Rack::Bug::CachePanel.record(:delete, key) do
|
117
|
+
delete_without_rack_bug(key, expiry)
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
alias_method_chain :decr, :rack_bug
|
122
|
+
alias_method_chain :get, :rack_bug
|
123
|
+
alias_method_chain :get_multi, :rack_bug
|
124
|
+
alias_method_chain :incr, :rack_bug
|
125
|
+
alias_method_chain :set, :rack_bug
|
126
|
+
alias_method_chain :add, :rack_bug
|
127
|
+
alias_method_chain :delete, :rack_bug
|
128
|
+
end
|
129
|
+
end
|