rails_lograge_middleware 1.0.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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d221d2def8934cd5cb4ba1b2c7e7d905d9f49fbf
4
+ data.tar.gz: f8dc81f7be64d41c3bf67ae0657b31de727e5117
5
+ SHA512:
6
+ metadata.gz: dcfef52c07af542e74446d83b5e681302f25b05b046729bf1488ba9554014645c94b625c0602934038d1dec1d3537294dd17a4a6f65570b9fa398c8179476345
7
+ data.tar.gz: a744c6b3b1319490a4105babeac84a1032fc50d4c566b9c650cf5d707c59cf548fe6caa0c05a05cd2201d6845f6cb0c1e7d9f6e25c0f4b445cfca2ed93e8493d
@@ -0,0 +1,43 @@
1
+ module RailsLogrageMiddleware
2
+ class Middleware
3
+ def initialize(app)
4
+ @app = app
5
+ end
6
+
7
+ def call(env)
8
+ begin
9
+ response = @app.call(env)
10
+ rescue Exception => ex
11
+ log_exception(ex, env)
12
+ raise
13
+ end
14
+
15
+ exception = env['action_dispatch.exception']
16
+ log_exception(exception, env) if exception
17
+
18
+ response
19
+ end
20
+
21
+ private
22
+ def log_exception(exception, env)
23
+ request = Rack::Request.new(env)
24
+
25
+ entry = {
26
+ method: request.request_method,
27
+ path: request.path,
28
+ format: env['action_dispatch.request.formats'][0].try(:symbol),
29
+ controller: env['action_dispatch.request.path_parameters'][:controller],
30
+ action: env['action_dispatch.request.path_parameters'][:action]
31
+ }
32
+ entry[:message] = "Error on #{entry[:path]} (#{entry[:controller]}##{entry[:action]}) #{exception.to_s}"
33
+ entry[:exception] = "#{exception.to_s} at #{exception.backtrace.first.strip}"
34
+
35
+ return unless entry
36
+
37
+ custom_options = Rails.configuration.rails_lograge_middleware.custom_options.call(exception, env, request)
38
+ entry.merge! custom_options
39
+
40
+ Lograge.logger.presence.error Rails.configuration.lograge.formatter.call(entry)
41
+ end
42
+ end
43
+ end
@@ -0,0 +1,13 @@
1
+ require 'rails/railtie'
2
+
3
+ module RailsLogrageMiddleware
4
+ Config = Struct.new(:custom_options)
5
+
6
+ class Railtie < Rails::Railtie
7
+ config.rails_lograge_middleware = Config.new
8
+
9
+ initializer 'rails_lograge_middleware.configure_middleware' do |app|
10
+ app.middleware.use Middleware
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,3 @@
1
+ module RailsLogrageMiddleware
2
+ VERSION = '1.0.0'
3
+ end
@@ -0,0 +1,7 @@
1
+ require 'rails_lograge_middleware/version'
2
+ require 'rails_lograge_middleware/middleware'
3
+
4
+ module RailsLogrageMiddleware
5
+ end
6
+
7
+ require 'rails_lograge_middleware/railtie' if defined?(Rails)
metadata ADDED
@@ -0,0 +1,116 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rails_lograge_middleware
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Michał Zalewski
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-10-01 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rspec
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: activesupport
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '4'
34
+ - - "<"
35
+ - !ruby/object:Gem::Version
36
+ version: '5.1'
37
+ type: :runtime
38
+ prerelease: false
39
+ version_requirements: !ruby/object:Gem::Requirement
40
+ requirements:
41
+ - - ">="
42
+ - !ruby/object:Gem::Version
43
+ version: '4'
44
+ - - "<"
45
+ - !ruby/object:Gem::Version
46
+ version: '5.1'
47
+ - !ruby/object:Gem::Dependency
48
+ name: railties
49
+ requirement: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - ">="
52
+ - !ruby/object:Gem::Version
53
+ version: '4'
54
+ - - "<"
55
+ - !ruby/object:Gem::Version
56
+ version: '5.1'
57
+ type: :runtime
58
+ prerelease: false
59
+ version_requirements: !ruby/object:Gem::Requirement
60
+ requirements:
61
+ - - ">="
62
+ - !ruby/object:Gem::Version
63
+ version: '4'
64
+ - - "<"
65
+ - !ruby/object:Gem::Version
66
+ version: '5.1'
67
+ - !ruby/object:Gem::Dependency
68
+ name: lograge
69
+ requirement: !ruby/object:Gem::Requirement
70
+ requirements:
71
+ - - "<"
72
+ - !ruby/object:Gem::Version
73
+ version: '1.0'
74
+ type: :runtime
75
+ prerelease: false
76
+ version_requirements: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - "<"
79
+ - !ruby/object:Gem::Version
80
+ version: '1.0'
81
+ description: Rails middleware for Lograge with support to log exceptions from Rails
82
+ and ActiveJobs
83
+ email: michal@mzalewski.net
84
+ executables: []
85
+ extensions: []
86
+ extra_rdoc_files: []
87
+ files:
88
+ - lib/rails_lograge_middleware.rb
89
+ - lib/rails_lograge_middleware/middleware.rb
90
+ - lib/rails_lograge_middleware/railtie.rb
91
+ - lib/rails_lograge_middleware/version.rb
92
+ homepage: http://rubygems.org/gems/lograge_rails_middleware
93
+ licenses:
94
+ - MIT
95
+ metadata: {}
96
+ post_install_message:
97
+ rdoc_options: []
98
+ require_paths:
99
+ - lib
100
+ required_ruby_version: !ruby/object:Gem::Requirement
101
+ requirements:
102
+ - - ">="
103
+ - !ruby/object:Gem::Version
104
+ version: '0'
105
+ required_rubygems_version: !ruby/object:Gem::Requirement
106
+ requirements:
107
+ - - ">="
108
+ - !ruby/object:Gem::Version
109
+ version: '0'
110
+ requirements: []
111
+ rubyforge_project:
112
+ rubygems_version: 2.5.1
113
+ signing_key:
114
+ specification_version: 4
115
+ summary: Rails middleware for Lograge
116
+ test_files: []