lumberjack 1.2.8 → 1.2.10
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +152 -58
- data/README.md +35 -6
- data/VERSION +1 -1
- data/lib/lumberjack/context.rb +13 -0
- data/lib/lumberjack/device/date_rolling_log_file.rb +10 -1
- data/lib/lumberjack/device/log_file.rb +8 -1
- data/lib/lumberjack/device/multi.rb +2 -1
- data/lib/lumberjack/device/null.rb +1 -1
- data/lib/lumberjack/device/rolling_log_file.rb +22 -22
- data/lib/lumberjack/device/size_rolling_log_file.rb +1 -1
- data/lib/lumberjack/device/writer.rb +21 -1
- data/lib/lumberjack/device.rb +16 -1
- data/lib/lumberjack/formatter/date_time_formatter.rb +2 -1
- data/lib/lumberjack/formatter/exception_formatter.rb +4 -2
- data/lib/lumberjack/formatter/id_formatter.rb +2 -1
- data/lib/lumberjack/formatter/inspect_formatter.rb +1 -1
- data/lib/lumberjack/formatter/object_formatter.rb +1 -1
- data/lib/lumberjack/formatter/pretty_print_formatter.rb +3 -1
- data/lib/lumberjack/formatter/string_formatter.rb +1 -1
- data/lib/lumberjack/formatter/strip_formatter.rb +1 -1
- data/lib/lumberjack/formatter/structured_formatter.rb +3 -1
- data/lib/lumberjack/formatter/truncate_formatter.rb +27 -0
- data/lib/lumberjack/formatter.rb +55 -9
- data/lib/lumberjack/log_entry.rb +10 -2
- data/lib/lumberjack/logger.rb +141 -18
- data/lib/lumberjack/rack/context.rb +1 -1
- data/lib/lumberjack/rack/request_id.rb +1 -1
- data/lib/lumberjack/rack/unit_of_work.rb +1 -1
- data/lib/lumberjack/rack.rb +1 -1
- data/lib/lumberjack/severity.rb +21 -1
- data/lib/lumberjack/tag_formatter.rb +19 -0
- data/lib/lumberjack/tagged_logger_support.rb +1 -1
- data/lib/lumberjack/tags.rb +6 -0
- data/lib/lumberjack/template.rb +15 -3
- data/lib/lumberjack.rb +20 -2
- metadata +8 -7
data/lib/lumberjack.rb
CHANGED
@@ -1,12 +1,13 @@
|
|
1
|
-
#
|
1
|
+
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require "rbconfig"
|
4
4
|
require "time"
|
5
5
|
require "securerandom"
|
6
6
|
require "logger"
|
7
|
+
require "fiber"
|
7
8
|
|
8
9
|
module Lumberjack
|
9
|
-
LINE_SEPARATOR = (RbConfig::CONFIG["host_os"] =~ /mswin/i ? "\r\n" : "\n")
|
10
|
+
LINE_SEPARATOR = ((RbConfig::CONFIG["host_os"] =~ /mswin/i) ? "\r\n" : "\n")
|
10
11
|
|
11
12
|
require_relative "lumberjack/severity"
|
12
13
|
require_relative "lumberjack/formatter"
|
@@ -32,6 +33,9 @@ module Lumberjack
|
|
32
33
|
#
|
33
34
|
# For the common use case of treating a single web request as a unit of work, see the
|
34
35
|
# Lumberjack::Rack::UnitOfWork class.
|
36
|
+
#
|
37
|
+
# @param [String] id The id for the unit of work.
|
38
|
+
# @return [void]
|
35
39
|
def unit_of_work(id = nil)
|
36
40
|
id ||= SecureRandom.hex(6)
|
37
41
|
context do
|
@@ -41,6 +45,8 @@ module Lumberjack
|
|
41
45
|
end
|
42
46
|
|
43
47
|
# Get the UniqueIdentifier for the current unit of work.
|
48
|
+
#
|
49
|
+
# @return [String, nil] The id for the current unit of work.
|
44
50
|
def unit_of_work_id
|
45
51
|
context[:unit_of_work_id]
|
46
52
|
end
|
@@ -53,6 +59,8 @@ module Lumberjack
|
|
53
59
|
#
|
54
60
|
# Otherwise, it will return the current context. If one doesn't exist, it will return a new one
|
55
61
|
# but that context will not be in any scope.
|
62
|
+
#
|
63
|
+
# @return [Lumberjack::Context] The current context if called without a block.
|
56
64
|
def context(&block)
|
57
65
|
current_context = Thread.current[:lumberjack_context]
|
58
66
|
if block
|
@@ -63,6 +71,9 @@ module Lumberjack
|
|
63
71
|
end
|
64
72
|
|
65
73
|
# Set the context to use within a block.
|
74
|
+
#
|
75
|
+
# @param [Lumberjack::Context] context The context to use within the block.
|
76
|
+
# @return [Object] The result of the block.
|
66
77
|
def use_context(context, &block)
|
67
78
|
current_context = Thread.current[:lumberjack_context]
|
68
79
|
begin
|
@@ -74,17 +85,24 @@ module Lumberjack
|
|
74
85
|
end
|
75
86
|
|
76
87
|
# Return true if inside a context block.
|
88
|
+
#
|
89
|
+
# @return [Boolean]
|
77
90
|
def context?
|
78
91
|
!!Thread.current[:lumberjack_context]
|
79
92
|
end
|
80
93
|
|
81
94
|
# Return the tags from the current context or nil if there are no tags.
|
95
|
+
#
|
96
|
+
# @return [Hash, nil]
|
82
97
|
def context_tags
|
83
98
|
context = Thread.current[:lumberjack_context]
|
84
99
|
context&.tags
|
85
100
|
end
|
86
101
|
|
87
102
|
# Set tags on the current context
|
103
|
+
#
|
104
|
+
# @param [Hash] tags The tags to set.
|
105
|
+
# @return [void]
|
88
106
|
def tag(tags)
|
89
107
|
context = Thread.current[:lumberjack_context]
|
90
108
|
context&.tag(tags)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: lumberjack
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.2.
|
4
|
+
version: 1.2.10
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Brian Durand
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-11-13 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -24,7 +24,7 @@ dependencies:
|
|
24
24
|
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: '0'
|
27
|
-
description:
|
27
|
+
description:
|
28
28
|
email:
|
29
29
|
- bbdurand@gmail.com
|
30
30
|
executables: []
|
@@ -55,6 +55,7 @@ files:
|
|
55
55
|
- lib/lumberjack/formatter/string_formatter.rb
|
56
56
|
- lib/lumberjack/formatter/strip_formatter.rb
|
57
57
|
- lib/lumberjack/formatter/structured_formatter.rb
|
58
|
+
- lib/lumberjack/formatter/truncate_formatter.rb
|
58
59
|
- lib/lumberjack/log_entry.rb
|
59
60
|
- lib/lumberjack/logger.rb
|
60
61
|
- lib/lumberjack/rack.rb
|
@@ -72,7 +73,7 @@ homepage: https://github.com/bdurand/lumberjack
|
|
72
73
|
licenses:
|
73
74
|
- MIT
|
74
75
|
metadata: {}
|
75
|
-
post_install_message:
|
76
|
+
post_install_message:
|
76
77
|
rdoc_options: []
|
77
78
|
require_paths:
|
78
79
|
- lib
|
@@ -87,8 +88,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
87
88
|
- !ruby/object:Gem::Version
|
88
89
|
version: '0'
|
89
90
|
requirements: []
|
90
|
-
rubygems_version: 3.
|
91
|
-
signing_key:
|
91
|
+
rubygems_version: 3.4.20
|
92
|
+
signing_key:
|
92
93
|
specification_version: 4
|
93
94
|
summary: A simple, powerful, and very fast logging utility that can be a drop in replacement
|
94
95
|
for Logger or ActiveSupport::BufferedLogger.
|