logtail-rails 0.1.0

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 (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: []