rack-bug 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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
|