logtail-rails 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (51) hide show
  1. checksums.yaml +7 -0
  2. data/.github/workflows/main.yml +144 -0
  3. data/.gitignore +23 -0
  4. data/.rspec +3 -0
  5. data/Gemfile +3 -0
  6. data/LICENSE.md +13 -0
  7. data/README.md +10 -0
  8. data/Rakefile +6 -0
  9. data/gemfiles/rails-3.0.gemfile +8 -0
  10. data/gemfiles/rails-3.1.gemfile +8 -0
  11. data/gemfiles/rails-3.2.gemfile +8 -0
  12. data/gemfiles/rails-4.0.gemfile +12 -0
  13. data/gemfiles/rails-4.1.gemfile +12 -0
  14. data/gemfiles/rails-4.2.gemfile +12 -0
  15. data/gemfiles/rails-5.0.gemfile +12 -0
  16. data/gemfiles/rails-5.1.gemfile +12 -0
  17. data/gemfiles/rails-5.2.gemfile +12 -0
  18. data/gemfiles/rails-6.0.gemfile +12 -0
  19. data/gemfiles/rails-6.1.gemfile +12 -0
  20. data/gemfiles/rails-edge.gemfile +10 -0
  21. data/lib/logtail-rails.rb +64 -0
  22. data/lib/logtail-rails/action_controller.rb +17 -0
  23. data/lib/logtail-rails/action_controller/log_subscriber.rb +25 -0
  24. data/lib/logtail-rails/action_controller/log_subscriber/logtail_log_subscriber.rb +46 -0
  25. data/lib/logtail-rails/action_dispatch.rb +20 -0
  26. data/lib/logtail-rails/action_dispatch/debug_exceptions.rb +51 -0
  27. data/lib/logtail-rails/action_view.rb +17 -0
  28. data/lib/logtail-rails/action_view/log_subscriber.rb +25 -0
  29. data/lib/logtail-rails/action_view/log_subscriber/logtail_log_subscriber.rb +84 -0
  30. data/lib/logtail-rails/active_record.rb +17 -0
  31. data/lib/logtail-rails/active_record/log_subscriber.rb +20 -0
  32. data/lib/logtail-rails/active_record/log_subscriber/logtail_log_subscriber.rb +52 -0
  33. data/lib/logtail-rails/active_support_log_subscriber.rb +39 -0
  34. data/lib/logtail-rails/config.rb +12 -0
  35. data/lib/logtail-rails/config/action_controller.rb +29 -0
  36. data/lib/logtail-rails/config/action_view.rb +29 -0
  37. data/lib/logtail-rails/config/active_record.rb +29 -0
  38. data/lib/logtail-rails/error_event.rb +62 -0
  39. data/lib/logtail-rails/logger.rb +20 -0
  40. data/lib/logtail-rails/overrides.rb +12 -0
  41. data/lib/logtail-rails/overrides/active_support_3_tagged_logging.rb +111 -0
  42. data/lib/logtail-rails/overrides/active_support_buffered_logger.rb +22 -0
  43. data/lib/logtail-rails/overrides/active_support_tagged_logging.rb +66 -0
  44. data/lib/logtail-rails/overrides/lograge.rb +18 -0
  45. data/lib/logtail-rails/overrides/rails_stdout_logging.rb +20 -0
  46. data/lib/logtail-rails/rack_logger.rb +59 -0
  47. data/lib/logtail-rails/railtie.rb +27 -0
  48. data/lib/logtail-rails/session_context.rb +37 -0
  49. data/lib/logtail-rails/version.rb +7 -0
  50. data/logtail-rails.gemspec +60 -0
  51. metadata +263 -0
@@ -0,0 +1,27 @@
1
+ module Logtail
2
+ module Frameworks
3
+ # Module for Rails specific code, such as the Railtie and any methods that assist
4
+ # with Rails setup.
5
+ module Rails
6
+ # Installs Logtail into your Rails app automatically.
7
+ class Railtie < ::Rails::Railtie
8
+ config.logtail = Config.instance
9
+
10
+ config.before_initialize do
11
+ Logtail::Config.instance.logger = Proc.new { ::Rails.logger }
12
+ end
13
+
14
+ # Must be loaded after initializers so that we respect any Logtail configuration set
15
+ initializer(:logtail, before: :build_middleware_stack, after: :load_config_initializers) do
16
+ Integrations::Rails.integrate!
17
+
18
+ # Install the Rack middlewares so that we capture structured data instead of
19
+ # raw text logs.
20
+ Integrations::Rails.middlewares.collect do |middleware_class|
21
+ config.app_middleware.use middleware_class
22
+ end
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,37 @@
1
+ require "logtail/contexts/session"
2
+ require "logtail-rack/middleware"
3
+
4
+ module Logtail
5
+ module Integrations
6
+ module Rails
7
+ # A Rack middleware that is responsible for adding the Session context
8
+ # {Logtail::Contexts::Session}.
9
+ class SessionContext < Logtail::Integrations::Rack::Middleware
10
+ def call(env)
11
+ id = get_session_id(env)
12
+ if id
13
+ context = Contexts::Session.new(id: id)
14
+ CurrentContext.add(context.to_hash)
15
+ end
16
+ @app.call(env)
17
+ end
18
+
19
+ private
20
+ def get_session_id(env)
21
+ session_key = ::Rails.application.config.session_options[:key]
22
+ request = ::ActionDispatch::Request.new(env)
23
+ extract_from_cookie(request, session_key)
24
+ rescue Exception => e
25
+ nil
26
+ end
27
+
28
+ def extract_from_cookie(request, session_key)
29
+ data = request
30
+ .cookie_jar
31
+ .signed_or_encrypted[session_key] || {}
32
+ data["session_id"]
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,7 @@
1
+ module Logtail
2
+ module Integrations
3
+ module Rails
4
+ VERSION = "0.1.0"
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,60 @@
1
+ lib = File.expand_path("../lib", __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+ require "logtail-rails/version"
4
+
5
+ Gem::Specification.new do |spec|
6
+ spec.name = "logtail-rails"
7
+ spec.version = Logtail::Integrations::Rails::VERSION
8
+ spec.authors = ["Logtail"]
9
+ spec.email = ["hi@logtail.com"]
10
+
11
+ spec.summary = %q{Logtail.com Rails integration}
12
+ spec.homepage = "https://github.com/logtail/logtail-ruby-rails"
13
+ spec.license = "ISC"
14
+
15
+ spec.required_ruby_version = '>= 2.2.0'
16
+
17
+ spec.metadata["homepage_uri"] = spec.homepage
18
+ spec.metadata["source_code_uri"] = "https://github.com/logtail/logtail-ruby-rails"
19
+ spec.metadata["changelog_uri"] = "https://github.com/logtail/logtail-ruby-rails/blob/main/README.md"
20
+
21
+ # Specify which files should be added to the gem when it is released.
22
+ # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
23
+ spec.files = Dir.chdir(File.expand_path('..', __FILE__)) do
24
+ `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
25
+ end
26
+ spec.bindir = "exe"
27
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
28
+ spec.require_paths = ["lib"]
29
+
30
+ spec.add_runtime_dependency "rails", ">= 3.0.0"
31
+ spec.add_runtime_dependency "logtail-ruby", "~> 0.1"
32
+ spec.add_runtime_dependency "logtail-rack", "~> 0.1"
33
+
34
+ spec.add_development_dependency "bundler", ">= 0.0"
35
+
36
+ spec.add_development_dependency "rake", ">= 0.8"
37
+ spec.add_development_dependency "rspec", "~> 3.0"
38
+
39
+ spec.add_development_dependency("bundler-audit", ">= 0")
40
+ spec.add_development_dependency("rails_stdout_logging", ">= 0")
41
+ spec.add_development_dependency("rspec-its", ">= 0")
42
+ spec.add_development_dependency("timecop", ">= 0")
43
+ spec.add_development_dependency('webmock', '~> 2.3')
44
+
45
+ rails_version = 0
46
+ if ENV.key?('RAILS_VERSION')
47
+ rails_version = ENV['RAILS_VERSION'].to_f
48
+ elsif ENV.key?('BUNDLE_GEMFILE')
49
+ matches = File.basename(ENV['BUNDLE_GEMFILE'], '.gemfile').match(/-([0-9.]+)\z/)
50
+ rails_version = matches[1].to_f if matches
51
+ end
52
+
53
+ if RUBY_PLATFORM == "java"
54
+ spec.add_development_dependency('activerecord-jdbcsqlite3-adapter', '>= 0')
55
+ elsif rails_version >= 3 && rails_version < 6
56
+ spec.add_development_dependency('sqlite3', '1.3.13')
57
+ else
58
+ spec.add_development_dependency('sqlite3', '~> 1.4.0')
59
+ end
60
+ end
metadata ADDED
@@ -0,0 +1,263 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: logtail-rails
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Logtail
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2021-02-13 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rails
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: 3.0.0
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: 3.0.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: logtail-ruby
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '0.1'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '0.1'
41
+ - !ruby/object:Gem::Dependency
42
+ name: logtail-rack
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '0.1'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '0.1'
55
+ - !ruby/object:Gem::Dependency
56
+ name: bundler
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rake
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0.8'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0.8'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rspec
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '3.0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: '3.0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: bundler-audit
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rails_stdout_logging
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: rspec-its
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: timecop
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: webmock
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - "~>"
158
+ - !ruby/object:Gem::Version
159
+ version: '2.3'
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - "~>"
165
+ - !ruby/object:Gem::Version
166
+ version: '2.3'
167
+ - !ruby/object:Gem::Dependency
168
+ name: sqlite3
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - "~>"
172
+ - !ruby/object:Gem::Version
173
+ version: 1.4.0
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - "~>"
179
+ - !ruby/object:Gem::Version
180
+ version: 1.4.0
181
+ description:
182
+ email:
183
+ - hi@logtail.com
184
+ executables: []
185
+ extensions: []
186
+ extra_rdoc_files: []
187
+ files:
188
+ - ".github/workflows/main.yml"
189
+ - ".gitignore"
190
+ - ".rspec"
191
+ - Gemfile
192
+ - LICENSE.md
193
+ - README.md
194
+ - Rakefile
195
+ - gemfiles/rails-3.0.gemfile
196
+ - gemfiles/rails-3.1.gemfile
197
+ - gemfiles/rails-3.2.gemfile
198
+ - gemfiles/rails-4.0.gemfile
199
+ - gemfiles/rails-4.1.gemfile
200
+ - gemfiles/rails-4.2.gemfile
201
+ - gemfiles/rails-5.0.gemfile
202
+ - gemfiles/rails-5.1.gemfile
203
+ - gemfiles/rails-5.2.gemfile
204
+ - gemfiles/rails-6.0.gemfile
205
+ - gemfiles/rails-6.1.gemfile
206
+ - gemfiles/rails-edge.gemfile
207
+ - lib/logtail-rails.rb
208
+ - lib/logtail-rails/action_controller.rb
209
+ - lib/logtail-rails/action_controller/log_subscriber.rb
210
+ - lib/logtail-rails/action_controller/log_subscriber/logtail_log_subscriber.rb
211
+ - lib/logtail-rails/action_dispatch.rb
212
+ - lib/logtail-rails/action_dispatch/debug_exceptions.rb
213
+ - lib/logtail-rails/action_view.rb
214
+ - lib/logtail-rails/action_view/log_subscriber.rb
215
+ - lib/logtail-rails/action_view/log_subscriber/logtail_log_subscriber.rb
216
+ - lib/logtail-rails/active_record.rb
217
+ - lib/logtail-rails/active_record/log_subscriber.rb
218
+ - lib/logtail-rails/active_record/log_subscriber/logtail_log_subscriber.rb
219
+ - lib/logtail-rails/active_support_log_subscriber.rb
220
+ - lib/logtail-rails/config.rb
221
+ - lib/logtail-rails/config/action_controller.rb
222
+ - lib/logtail-rails/config/action_view.rb
223
+ - lib/logtail-rails/config/active_record.rb
224
+ - lib/logtail-rails/error_event.rb
225
+ - lib/logtail-rails/logger.rb
226
+ - lib/logtail-rails/overrides.rb
227
+ - lib/logtail-rails/overrides/active_support_3_tagged_logging.rb
228
+ - lib/logtail-rails/overrides/active_support_buffered_logger.rb
229
+ - lib/logtail-rails/overrides/active_support_tagged_logging.rb
230
+ - lib/logtail-rails/overrides/lograge.rb
231
+ - lib/logtail-rails/overrides/rails_stdout_logging.rb
232
+ - lib/logtail-rails/rack_logger.rb
233
+ - lib/logtail-rails/railtie.rb
234
+ - lib/logtail-rails/session_context.rb
235
+ - lib/logtail-rails/version.rb
236
+ - logtail-rails.gemspec
237
+ homepage: https://github.com/logtail/logtail-ruby-rails
238
+ licenses:
239
+ - ISC
240
+ metadata:
241
+ homepage_uri: https://github.com/logtail/logtail-ruby-rails
242
+ source_code_uri: https://github.com/logtail/logtail-ruby-rails
243
+ changelog_uri: https://github.com/logtail/logtail-ruby-rails/blob/main/README.md
244
+ post_install_message:
245
+ rdoc_options: []
246
+ require_paths:
247
+ - lib
248
+ required_ruby_version: !ruby/object:Gem::Requirement
249
+ requirements:
250
+ - - ">="
251
+ - !ruby/object:Gem::Version
252
+ version: 2.2.0
253
+ required_rubygems_version: !ruby/object:Gem::Requirement
254
+ requirements:
255
+ - - ">="
256
+ - !ruby/object:Gem::Version
257
+ version: '0'
258
+ requirements: []
259
+ rubygems_version: 3.2.3
260
+ signing_key:
261
+ specification_version: 4
262
+ summary: Logtail.com Rails integration
263
+ test_files: []