threaded_logging 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/threaded_logging.rb +15 -0
  3. metadata +45 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 1ec9733e11478c13830611b92a9676a4d534f249
4
+ data.tar.gz: 7e3ce87497d022a55785d1cc63747607177b339c
5
+ SHA512:
6
+ metadata.gz: 280f819d54e600486614a4c6eaf2103b785783aaa8ae7bab3cba45543c18947656c26563178af7fdb971d9b916b73779d62d433e58f496b9874e38ab1e8a82de
7
+ data.tar.gz: 049cc10cff63319955141b368dafa3ce96f93bd5da5bc1118a663013cb045a942c53eacf22a46518050e299df40debddc65a041a505b5b8d32d935d7cc65b275
@@ -0,0 +1,15 @@
1
+ require "English"
2
+
3
+ module ThreadedLogging
4
+ def call(severity, time, _progname, msg)
5
+ time_string = time.strftime("%Y-%m-%dT%H:%M:%S.") << format("%06d", time.usec)
6
+ thread_id = Digest::MD5.hexdigest([Thread.current.object_id, $PID].join)[0...8]
7
+
8
+ metadata = "#{severity[0]} [#{time_string}] ##{thread_id}:"
9
+ message = ""
10
+ msg.lines.each { |line| message << "#{metadata} #{line}" }
11
+ "#{message}\n"
12
+ end
13
+ end
14
+
15
+ ::Logger::Formatter.prepend(ThreadedLogging)
metadata ADDED
@@ -0,0 +1,45 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: threaded_logging
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Yuri Smirnov
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-05-23 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: Add current thread's fingerprint to all your logs.
14
+ email: tycoooon@gmail.com
15
+ executables: []
16
+ extensions: []
17
+ extra_rdoc_files: []
18
+ files:
19
+ - lib/threaded_logging.rb
20
+ homepage: http://github.com
21
+ licenses:
22
+ - MIT
23
+ metadata: {}
24
+ post_install_message:
25
+ rdoc_options: []
26
+ require_paths:
27
+ - lib
28
+ required_ruby_version: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: '0'
33
+ required_rubygems_version: !ruby/object:Gem::Requirement
34
+ requirements:
35
+ - - ">="
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ requirements: []
39
+ rubyforge_project:
40
+ rubygems_version: 2.5.1
41
+ signing_key:
42
+ specification_version: 4
43
+ summary: Better formatter for rails logger
44
+ test_files: []
45
+ has_rdoc: