sql_tracer 0.0.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.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/sql_tracer.rb +28 -0
  3. metadata +44 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: af23a3259abebd3425188fe447b819f32ec9e7f5
4
+ data.tar.gz: 9db84e52fffe16f05c5967d9ca2e48d4a5f82711
5
+ SHA512:
6
+ metadata.gz: ca816309a83bdf9ae2abb7c3a24116c6093e959820e65dbf1ab6b148739fbc1a22365db9d93968b9b7c2f358aafa6ce4c4cf4ccc404f91746024a282f01fa92d
7
+ data.tar.gz: feb5dad7d36ff82215602ca9c233189ded04d15785da54b9876f5535076aa68fe50ac0660470b6802548c60e692b7081a87a03c6eed1ca519befac891f087b24
data/lib/sql_tracer.rb ADDED
@@ -0,0 +1,28 @@
1
+ module SqlTracer
2
+ module SqlLogger
3
+
4
+ extend ActiveSupport::Concern
5
+
6
+ included do
7
+
8
+ alias_method :execute_without_stack, :execute
9
+
10
+ def execute(*args)
11
+ sql = args.first
12
+ if sql =~ /^\s*(insert|update|delete)\s/i
13
+ puts sql
14
+ puts Thread.current.backtrace.select { |path| !path.include?('/.rvm/gems/') }
15
+ end
16
+ execute_without_stack(*args)
17
+ end
18
+ end
19
+ end
20
+ end
21
+
22
+ ActiveSupport.on_load(:active_record) do
23
+ begin
24
+ require 'active_record/connection_adapters/mysql2_adapter'
25
+ ActiveRecord::ConnectionAdapters::Mysql2Adapter.send(:include, SqlTracer::SqlLogger)
26
+ rescue LoadError, NameError
27
+ end
28
+ end
metadata ADDED
@@ -0,0 +1,44 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sql_tracer
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - UI
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-05-15 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: log sql and backtrace when execute sql
14
+ email:
15
+ - eng-ui@freewheel.tv
16
+ executables: []
17
+ extensions: []
18
+ extra_rdoc_files: []
19
+ files:
20
+ - lib/sql_tracer.rb
21
+ homepage: http://git.dev.fwmrm.net/ui/ui
22
+ licenses: []
23
+ metadata: {}
24
+ post_install_message:
25
+ rdoc_options: []
26
+ require_paths:
27
+ - lib
28
+ required_ruby_version: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: '0'
33
+ required_rubygems_version: !ruby/object:Gem::Requirement
34
+ requirements:
35
+ - - ">="
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ requirements: []
39
+ rubyforge_project:
40
+ rubygems_version: 2.4.3
41
+ signing_key:
42
+ specification_version: 4
43
+ summary: UI Redis Framework Extension
44
+ test_files: []