sql-query-stats 0.1.3 → 0.1.4

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 4e7692004539df5eed7b13007df62d3e752f6778
4
- data.tar.gz: cab8f10e73ac705769e88dd6b56eb8e4757bf812
3
+ metadata.gz: 758d6da7e1b474b3ebf8a4f2c503cc04c8bad54e
4
+ data.tar.gz: 3f44ed27eb85b672c5dc2d091ccbc47c07a82087
5
5
  SHA512:
6
- metadata.gz: fe01cd7895e29430a6ad57e3cd7cf3243535879302ee09f69cc6bd09b2a4440cc900a51eb7f2d3ec3955dc897050a4b86423254d45c1327027ee25ba3097e26a
7
- data.tar.gz: f6c56df6cfa41aa4a58f4ef97331f73c42a43f67a2329bfcdc1f01ba526335d7a619a4976d5c54807974a4ced82e3c2d5bce124340b9a0d19578bf18aaec81cd
6
+ metadata.gz: 7380a3115576183c475e2a4e4ca805b74719f94e32e66ce4decd88fe0366fa0673d51a192eb7a0c37eba7e5a98b3647b813e26c56467ca4e3e3491338770caaa
7
+ data.tar.gz: d448e35d1edc60dcfd13754093b2ad26732b19b72216640e113daf87ef3505e4aead84e92de67ae329e2fe216aa7cf5026a25011ccb18935a6ff0a0e8b523c78
data/README.md CHANGED
@@ -1,11 +1,16 @@
1
- # SqlQueryStats
1
+ # Sql Query Stats
2
2
 
3
- Short description and motivation.
3
+ This Gem adds some useful SQL query stats to your Rails logs.
4
4
 
5
- ## Usage
6
- How to use my plugin.
5
+ #### Reported stats include
7
6
 
8
- ## Installation
7
+ * Query count
8
+ * Query cache used
9
+ * Slowest query
10
+ * Slowest query duration
11
+ * Total query duration
12
+
13
+ ## Installation & usage
9
14
  Add this line to your application's Gemfile:
10
15
 
11
16
  ```ruby
@@ -19,11 +24,8 @@ $ bundle
19
24
 
20
25
  Or install it yourself as:
21
26
  ```bash
22
- $ gem install sql_query_stats
27
+ $ gem install sql-query-stats
23
28
  ```
24
29
 
25
- ## Contributing
26
- Contribution directions go here.
27
-
28
30
  ## License
29
31
  The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
@@ -2,3 +2,4 @@ require 'sql_query_stats/version'
2
2
  require 'sql_query_stats/reporter'
3
3
  require 'sql_query_stats/controller_runtime'
4
4
  require 'sql_query_stats/initializer'
5
+ require 'sql_query_stats/sanitizer'
@@ -45,7 +45,7 @@ module SqlQueryStats
45
45
  end
46
46
 
47
47
  def check_slowest_query(event)
48
- reportable_queries = %w[INSERT SELECT UPDATE]
48
+ reportable_queries = %w[SELECT INSERT UPDATE]
49
49
  return unless event.duration > stats[:slowest_query_duration]
50
50
  return unless event.payload[:sql].start_with?(*reportable_queries)
51
51
 
@@ -55,7 +55,7 @@ module SqlQueryStats
55
55
  def report_slowest_query(event)
56
56
  duration = stats[:slowest_query_duration] + event.duration
57
57
 
58
- log(:slowest_query, event.payload[:sql])
58
+ log(:slowest_query, Sanitizer.sanitize(event.payload[:sql]))
59
59
  log(:slowest_query_duration, duration.round(1))
60
60
  end
61
61
  end
@@ -0,0 +1,27 @@
1
+ module SqlQueryStats
2
+ # SqlQueryStats Sanitizer
3
+ class Sanitizer
4
+ def self.sanitize(sql_query_string)
5
+ filters = Rails.application.config.filter_parameters
6
+ sql = sql_query_string.dup
7
+ sql = filter_params(filters, sql)
8
+ filter_values(sql)
9
+ end
10
+
11
+ def self.filter_params(filters, sql)
12
+ filters.each do |filter|
13
+ sql.gsub!(/`#{filter}` = '[^']+'/, "#{filter} = '[FILTERED]'")
14
+ end
15
+
16
+ sql
17
+ end
18
+
19
+ def self.filter_values(sql)
20
+ sql.scan(/(?:VALUES(?:\s?)\()(.*)(?:\)+)/) do |value|
21
+ sql.gsub!(/#{value}/, "'[FILTERED]'")
22
+ end
23
+
24
+ sql
25
+ end
26
+ end
27
+ end
@@ -1,3 +1,3 @@
1
1
  module SqlQueryStats
2
- VERSION = '0.1.3'.freeze
2
+ VERSION = '0.1.4'.freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sql-query-stats
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.3
4
+ version: 0.1.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Ben Barber
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2018-02-26 00:00:00.000000000 Z
11
+ date: 2018-03-03 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -38,7 +38,10 @@ dependencies:
38
38
  - - ">"
39
39
  - !ruby/object:Gem::Version
40
40
  version: '1.2'
41
- description: SqlQueryStats
41
+ description: |-
42
+ Adds some useful SQL query stats to your Rails logs, \
43
+ reported stats include, query count, slowest query and \
44
+ slowest query duration
42
45
  email:
43
46
  - contact@benbarber.co.uk
44
47
  executables: []
@@ -52,6 +55,7 @@ files:
52
55
  - lib/sql_query_stats/controller_runtime.rb
53
56
  - lib/sql_query_stats/initializer.rb
54
57
  - lib/sql_query_stats/reporter.rb
58
+ - lib/sql_query_stats/sanitizer.rb
55
59
  - lib/sql_query_stats/version.rb
56
60
  - lib/tasks/sql_query_stats_tasks.rake
57
61
  homepage: https://github.com/benbarber/sql-query-stats
@@ -77,5 +81,5 @@ rubyforge_project:
77
81
  rubygems_version: 2.6.11
78
82
  signing_key:
79
83
  specification_version: 4
80
- summary: Get more information from ActiveRecord
84
+ summary: Adds some useful SQL query stats to your Rails logs.
81
85
  test_files: []