dry-logger 1.0.3 → 1.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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +23 -2
- data/LICENSE +1 -1
- data/README.md +4 -3
- data/dry-logger.gemspec +3 -3
- data/lib/dry/logger/backends/stream.rb +17 -2
- data/lib/dry/logger/constants.rb +2 -2
- data/lib/dry/logger/dispatcher.rb +26 -15
- data/lib/dry/logger/formatters/template.rb +1 -1
- data/lib/dry/logger/version.rb +1 -1
- data/lib/dry/logger.rb +0 -4
- metadata +9 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 8ade638e79062ec058eb9745a134da64d4a97a6ee0ae794ebddc60c2463e7a74
|
4
|
+
data.tar.gz: f68f26b0565381b9a1d1c347d7be52d4d38a6cea69cfa2d60daaacc7a57b5124
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4f12c24a3bee1e597b5eabdfe2b0905e2c94bd22821ec979092ad369bfa0d120f4ff84f8fd20cad9a15b6620e33036cc34e682790fb27f78952136c0cd09e0a5
|
7
|
+
data.tar.gz: cbca9d7176c727f69b82a99ce0fca122c8084c702a16525cbe9c24ff6c7155d845debfcde5b455a969930b7cb24baecad1bab3790f8843f7e7469d83eb85fb57
|
data/CHANGELOG.md
CHANGED
@@ -1,6 +1,27 @@
|
|
1
1
|
<!--- DO NOT EDIT THIS FILE - IT'S AUTOMATICALLY GENERATED VIA DEVTOOLS --->
|
2
2
|
|
3
|
-
##
|
3
|
+
## 1.1.0 2025-04-17
|
4
|
+
|
5
|
+
### Added
|
6
|
+
|
7
|
+
- Support `::Logger`'s log rotation in stream-based logger backends, via `shift_size:` and `shift_age:` arguments (@wuarmin in #31)
|
8
|
+
|
9
|
+
[Compare v1.0.4...v1.1.0](https://github.com/dry-rb/dry-logger/compare/v1.0.4...v1.1.0)
|
10
|
+
|
11
|
+
## 1.0.4 2024-05-10
|
12
|
+
|
13
|
+
|
14
|
+
### Fixed
|
15
|
+
|
16
|
+
- Accept log messages via given block, ensuring compatibility with standard Ruby logger (via #28) (@komidore64)
|
17
|
+
|
18
|
+
### Changed
|
19
|
+
|
20
|
+
- Drop support for Ruby 2.7 (via #29) (@timriley)
|
21
|
+
|
22
|
+
[Compare v1.0.3...v1.0.4](https://github.com/dry-rb/dry-logger/compare/v1.0.3...v1.0.4)
|
23
|
+
|
24
|
+
## 1.0.3 2022-12-09
|
4
25
|
|
5
26
|
|
6
27
|
### Added
|
@@ -8,7 +29,7 @@
|
|
8
29
|
- Support for ruby 2.7 (needs backports gem that *you* need to add to your Gemfile) (via #24) (@solnic)
|
9
30
|
|
10
31
|
|
11
|
-
[Compare v1.0.2...
|
32
|
+
[Compare v1.0.2...v1.0.3](https://github.com/dry-rb/dry-logger/compare/v1.0.2...v1.0.3)
|
12
33
|
|
13
34
|
## 1.0.2 2022-11-24
|
14
35
|
|
data/LICENSE
CHANGED
data/README.md
CHANGED
@@ -1,8 +1,9 @@
|
|
1
1
|
<!--- this file is synced from dry-rb/template-gem project -->
|
2
|
+
|
2
3
|
[gem]: https://rubygems.org/gems/dry-logger
|
3
4
|
[actions]: https://github.com/dry-rb/dry-logger/actions
|
4
5
|
|
5
|
-
# dry-logger [][gem] [][gem] [][actions]
|
6
7
|
|
7
8
|
## Links
|
8
9
|
|
@@ -14,8 +15,8 @@
|
|
14
15
|
|
15
16
|
This library officially supports the following Ruby versions:
|
16
17
|
|
17
|
-
* MRI `>=
|
18
|
-
* jruby `>= 9.
|
18
|
+
* MRI `>= 3.0`
|
19
|
+
* jruby `>= 9.4` (not tested on CI)
|
19
20
|
|
20
21
|
## License
|
21
22
|
|
data/dry-logger.gemspec
CHANGED
@@ -8,8 +8,8 @@ require "dry/logger/version"
|
|
8
8
|
|
9
9
|
Gem::Specification.new do |spec|
|
10
10
|
spec.name = "dry-logger"
|
11
|
-
spec.authors = ["Luca Guidi"]
|
12
|
-
spec.email = ["me@lucaguidi.com"]
|
11
|
+
spec.authors = ["Luca Guidi", "Peter Solnica"]
|
12
|
+
spec.email = ["me@lucaguidi.com", "peter@solnica.online"]
|
13
13
|
spec.license = "MIT"
|
14
14
|
spec.version = Dry::Logger::VERSION.dup
|
15
15
|
|
@@ -26,7 +26,7 @@ Gem::Specification.new do |spec|
|
|
26
26
|
spec.metadata["source_code_uri"] = "https://github.com/dry-rb/dry-logger"
|
27
27
|
spec.metadata["bug_tracker_uri"] = "https://github.com/dry-rb/dry-logger/issues"
|
28
28
|
|
29
|
-
spec.required_ruby_version = ">=
|
29
|
+
spec.required_ruby_version = ">= 3.0"
|
30
30
|
|
31
31
|
# to update dependencies edit project.yml
|
32
32
|
|
@@ -21,8 +21,23 @@ module Dry
|
|
21
21
|
|
22
22
|
# @since 0.1.0
|
23
23
|
# @api private
|
24
|
-
def initialize(
|
25
|
-
|
24
|
+
def initialize( # rubocop:disable Style/ParameterLists
|
25
|
+
stream:,
|
26
|
+
formatter:,
|
27
|
+
level: DEFAULT_LEVEL,
|
28
|
+
progname: nil,
|
29
|
+
log_if: nil,
|
30
|
+
shift_age: nil,
|
31
|
+
shift_size: nil,
|
32
|
+
**logger_options
|
33
|
+
)
|
34
|
+
super(
|
35
|
+
stream,
|
36
|
+
shift_age,
|
37
|
+
shift_size,
|
38
|
+
progname: progname,
|
39
|
+
**logger_options
|
40
|
+
)
|
26
41
|
|
27
42
|
@stream = stream
|
28
43
|
@level = LEVELS[level]
|
data/lib/dry/logger/constants.rb
CHANGED
@@ -58,7 +58,7 @@ module Dry
|
|
58
58
|
|
59
59
|
# @since 1.0.0
|
60
60
|
# @api private
|
61
|
-
LEVEL_RANGE = (DEBUG..UNKNOWN)
|
61
|
+
LEVEL_RANGE = (DEBUG..UNKNOWN)
|
62
62
|
|
63
63
|
# @since 1.0.0
|
64
64
|
# @api private
|
@@ -86,7 +86,7 @@ module Dry
|
|
86
86
|
|
87
87
|
# @since 1.0.0
|
88
88
|
# @api private
|
89
|
-
BACKEND_OPT_KEYS = DEFAULT_OPTS.keys.freeze
|
89
|
+
BACKEND_OPT_KEYS = [*DEFAULT_OPTS.keys, :shift_age, :shift_size, :shift_period_suffix].freeze
|
90
90
|
|
91
91
|
# @since 1.0.0
|
92
92
|
# @api private
|
@@ -110,8 +110,8 @@ module Dry
|
|
110
110
|
# @see Dispatcher#log
|
111
111
|
# @api public
|
112
112
|
# @return [true]
|
113
|
-
def unknown(message = nil, **payload)
|
114
|
-
log(:unknown, message, **payload)
|
113
|
+
def unknown(message = nil, **payload, &block)
|
114
|
+
log(:unknown, message, **payload, &block)
|
115
115
|
end
|
116
116
|
|
117
117
|
# Log an entry with DEBUG severity
|
@@ -119,8 +119,8 @@ module Dry
|
|
119
119
|
# @see Dispatcher#log
|
120
120
|
# @api public
|
121
121
|
# @return [true]
|
122
|
-
def debug(message = nil, **payload)
|
123
|
-
log(:debug, message, **payload)
|
122
|
+
def debug(message = nil, **payload, &block)
|
123
|
+
log(:debug, message, **payload, &block)
|
124
124
|
end
|
125
125
|
|
126
126
|
# Log an entry with INFO severity
|
@@ -128,8 +128,8 @@ module Dry
|
|
128
128
|
# @see Dispatcher#log
|
129
129
|
# @api public
|
130
130
|
# @return [true]
|
131
|
-
def info(message = nil, **payload)
|
132
|
-
log(:info, message, **payload)
|
131
|
+
def info(message = nil, **payload, &block)
|
132
|
+
log(:info, message, **payload, &block)
|
133
133
|
end
|
134
134
|
|
135
135
|
# Log an entry with WARN severity
|
@@ -137,8 +137,8 @@ module Dry
|
|
137
137
|
# @see Dispatcher#log
|
138
138
|
# @api public
|
139
139
|
# @return [true]
|
140
|
-
def warn(message = nil, **payload)
|
141
|
-
log(:warn, message, **payload)
|
140
|
+
def warn(message = nil, **payload, &block)
|
141
|
+
log(:warn, message, **payload, &block)
|
142
142
|
end
|
143
143
|
|
144
144
|
# Log an entry with ERROR severity
|
@@ -146,8 +146,8 @@ module Dry
|
|
146
146
|
# @see Dispatcher#log
|
147
147
|
# @api public
|
148
148
|
# @return [true]
|
149
|
-
def error(message = nil, **payload)
|
150
|
-
log(:error, message, **payload)
|
149
|
+
def error(message = nil, **payload, &block)
|
150
|
+
log(:error, message, **payload, &block)
|
151
151
|
end
|
152
152
|
|
153
153
|
# Log an entry with FATAL severity
|
@@ -155,8 +155,8 @@ module Dry
|
|
155
155
|
# @see Dispatcher#log
|
156
156
|
# @api public
|
157
157
|
# @return [true]
|
158
|
-
def fatal(message = nil, **payload)
|
159
|
-
log(:fatal, message, **payload)
|
158
|
+
def fatal(message = nil, **payload, &block)
|
159
|
+
log(:fatal, message, **payload, &block)
|
160
160
|
end
|
161
161
|
|
162
162
|
BACKEND_METHODS.each do |name|
|
@@ -179,6 +179,9 @@ module Dry
|
|
179
179
|
# @example logging a message
|
180
180
|
# logger.log(:info, "Hello World")
|
181
181
|
#
|
182
|
+
# @example logging a message by passing a block
|
183
|
+
# logger.log(:debug, "Sidecar") { "Hello World" }
|
184
|
+
#
|
182
185
|
# @example logging payload
|
183
186
|
# logger.log(:info, verb: "GET", path: "/users")
|
184
187
|
#
|
@@ -196,17 +199,25 @@ module Dry
|
|
196
199
|
# @param [Symbol] severity The log severity name
|
197
200
|
# @param [String] message Optional message
|
198
201
|
# @param [Hash] payload Optional log entry payload
|
202
|
+
# @yield
|
203
|
+
# @yieldreturn [String] Message to be logged
|
199
204
|
#
|
200
205
|
# @since 1.0.0
|
201
206
|
# @return [true]
|
202
207
|
# @api public
|
203
|
-
def log(severity, message = nil, **payload)
|
208
|
+
def log(severity, message = nil, **payload, &block)
|
204
209
|
case message
|
205
|
-
when Hash then log(severity,
|
210
|
+
when Hash then log(severity, **message, &block)
|
206
211
|
else
|
212
|
+
if block
|
213
|
+
progname = message
|
214
|
+
message = block.call
|
215
|
+
end
|
216
|
+
progname ||= id
|
217
|
+
|
207
218
|
entry = Entry.new(
|
208
219
|
clock: clock,
|
209
|
-
progname:
|
220
|
+
progname: progname,
|
210
221
|
severity: severity,
|
211
222
|
tags: @tags,
|
212
223
|
message: message,
|
data/lib/dry/logger/version.rb
CHANGED
data/lib/dry/logger.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,15 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: dry-logger
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0
|
4
|
+
version: 1.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Luca Guidi
|
8
|
-
|
8
|
+
- Peter Solnica
|
9
|
+
autorequire:
|
9
10
|
bindir: bin
|
10
11
|
cert_chain: []
|
11
|
-
date:
|
12
|
+
date: 2025-04-16 00:00:00.000000000 Z
|
12
13
|
dependencies:
|
13
14
|
- !ruby/object:Gem::Dependency
|
14
15
|
name: rspec
|
@@ -27,6 +28,7 @@ dependencies:
|
|
27
28
|
description: Logging for Ruby
|
28
29
|
email:
|
29
30
|
- me@lucaguidi.com
|
31
|
+
- peter@solnica.online
|
30
32
|
executables: []
|
31
33
|
extensions: []
|
32
34
|
extra_rdoc_files: []
|
@@ -62,7 +64,7 @@ metadata:
|
|
62
64
|
changelog_uri: https://github.com/dry-rb/dry-logger/blob/main/CHANGELOG.md
|
63
65
|
source_code_uri: https://github.com/dry-rb/dry-logger
|
64
66
|
bug_tracker_uri: https://github.com/dry-rb/dry-logger/issues
|
65
|
-
post_install_message:
|
67
|
+
post_install_message:
|
66
68
|
rdoc_options: []
|
67
69
|
require_paths:
|
68
70
|
- lib
|
@@ -70,15 +72,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
70
72
|
requirements:
|
71
73
|
- - ">="
|
72
74
|
- !ruby/object:Gem::Version
|
73
|
-
version: '
|
75
|
+
version: '3.0'
|
74
76
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
75
77
|
requirements:
|
76
78
|
- - ">="
|
77
79
|
- !ruby/object:Gem::Version
|
78
80
|
version: '0'
|
79
81
|
requirements: []
|
80
|
-
rubygems_version: 3.
|
81
|
-
signing_key:
|
82
|
+
rubygems_version: 3.3.27
|
83
|
+
signing_key:
|
82
84
|
specification_version: 4
|
83
85
|
summary: Logging for Ruby
|
84
86
|
test_files: []
|