lograge_active_job 1.2.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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 056b03f7989ac62606553e6e6bdb55f754df5a6f
4
+ data.tar.gz: fc2622570bc658b936f1c7f77f14d02fe9279f88
5
+ SHA512:
6
+ metadata.gz: 9c3e688451a409d39bcae6b04b52c99e87acc6eb5065c9bc599706d4255891fe7a3b715080f48dc1b09c006feb695ec96283767f0c9fd47fd0ee081115947863
7
+ data.tar.gz: 7158a485723942e22ab1f8c60ab42e534878c02d61c1ae0d01e942b36ea440679314dd3a767db64b5b77e2eb5e3244856c341f5a1e79b364d2aa219b55d798c0
@@ -0,0 +1,6 @@
1
+ require 'lograge_active_job/version'
2
+
3
+ module LogrageActiveJob
4
+ end
5
+
6
+ require 'lograge_active_job/railtie' if defined?(Rails)
@@ -0,0 +1,29 @@
1
+ module LogrageActiveJob
2
+ module ActiveJob
3
+ extend ActiveSupport::Concern
4
+
5
+ included do
6
+ rescue_from(StandardError) do |e|
7
+ log_exception(e)
8
+ end
9
+
10
+ def log_exception(e)
11
+ entry = {
12
+ name: self.class.name,
13
+ id: self.job_id,
14
+ arguments: self.arguments.any? ? ::ActiveJob::Arguments.serialize(self.arguments) : [],
15
+ queue_name: self.queue_name,
16
+ error: "#{e.class}: #{e.message}",
17
+ backtrace: e.backtrace,
18
+ }
19
+
20
+ if Rails.configuration.lograge_active_job.custom_options
21
+ custom_options = Rails.configuration.lograge_active_job.custom_options.call(e, self)
22
+ entry.merge! custom_options
23
+ end
24
+
25
+ self.logger.public_send Lograge.log_level, Lograge.formatter.call(entry)
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,16 @@
1
+ require 'rails/railtie'
2
+
3
+ module LogrageActiveJob
4
+ Config = Struct.new(:custom_options)
5
+
6
+ class Railtie < Rails::Railtie
7
+ config.lograge_active_job = Config.new
8
+
9
+ initializer('lograge_active_job.active_job') do
10
+ ActiveSupport.on_load(:active_job) do
11
+ require 'lograge_active_job/active_job'
12
+ include LogrageActiveJob::ActiveJob
13
+ end
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,3 @@
1
+ module LogrageActiveJob
2
+ VERSION = '1.0.0'
3
+ end
@@ -0,0 +1,19 @@
1
+ Gem::Specification.new do |s|
2
+ s.name = 'lograge_active_job'
3
+ s.version = '1.2.0'
4
+ s.summary = 'ActiveJob logging for Lograge'
5
+ s.description = 'ActiveJob logging for Lograge'
6
+ s.authors = ['Armand Mégrot']
7
+ s.email = 'armand.megrot@gmail.com'
8
+ s.homepage = 'https://github.com/armandmgt/lograge_active_job'
9
+ s.license = 'MIT'
10
+
11
+ s.files = Dir.glob('lib/**/*') + [ 'lograge-active-job.gemspec' ]
12
+
13
+ s.add_development_dependency 'rspec', '~> 3.5'
14
+
15
+ s.add_runtime_dependency 'activesupport', '>= 4'
16
+ s.add_runtime_dependency 'railties', '>= 4'
17
+
18
+ s.add_runtime_dependency 'lograge', '< 1.0'
19
+ end
metadata ADDED
@@ -0,0 +1,104 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: lograge_active_job
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.2.0
5
+ platform: ruby
6
+ authors:
7
+ - Armand Mégrot
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2019-03-07 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: '3.5'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '3.5'
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
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '4'
41
+ - !ruby/object:Gem::Dependency
42
+ name: railties
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '4'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '4'
55
+ - !ruby/object:Gem::Dependency
56
+ name: lograge
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "<"
60
+ - !ruby/object:Gem::Version
61
+ version: '1.0'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "<"
67
+ - !ruby/object:Gem::Version
68
+ version: '1.0'
69
+ description: ActiveJob logging for Lograge
70
+ email: armand.megrot@gmail.com
71
+ executables: []
72
+ extensions: []
73
+ extra_rdoc_files: []
74
+ files:
75
+ - lib/lograge_active_job.rb
76
+ - lib/lograge_active_job/active_job.rb
77
+ - lib/lograge_active_job/railtie.rb
78
+ - lib/lograge_active_job/version.rb
79
+ - lograge-active-job.gemspec
80
+ homepage: https://github.com/armandmgt/lograge_active_job
81
+ licenses:
82
+ - MIT
83
+ metadata: {}
84
+ post_install_message:
85
+ rdoc_options: []
86
+ require_paths:
87
+ - lib
88
+ required_ruby_version: !ruby/object:Gem::Requirement
89
+ requirements:
90
+ - - ">="
91
+ - !ruby/object:Gem::Version
92
+ version: '0'
93
+ required_rubygems_version: !ruby/object:Gem::Requirement
94
+ requirements:
95
+ - - ">="
96
+ - !ruby/object:Gem::Version
97
+ version: '0'
98
+ requirements: []
99
+ rubyforge_project:
100
+ rubygems_version: 2.5.2.3
101
+ signing_key:
102
+ specification_version: 4
103
+ summary: ActiveJob logging for Lograge
104
+ test_files: []