minato_logger 0.1.13.pre.4 → 0.1.13

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 8912274da7dd77fae6f70e2236079b5ed24df2aef0326ef1cd0467aed0cd2dcc
4
- data.tar.gz: 9fe88a71c8273fa4945b74d3d640761b6fc8bfb2c2bca0ae63e25cfb3b82fc2d
3
+ metadata.gz: e7f37f246b04ca0fb8200abd73730c82c7acd74e377a092241a7a9c4b81c432a
4
+ data.tar.gz: e9900da1f8a50a21c5f52ea1d6313394201256b2c9740d032777e8201da25307
5
5
  SHA512:
6
- metadata.gz: d7974899c02eee1e4f366b3391fbbb3c386dbbea2870ce4bc2f61396e4baf495c8b8bac7c32d9239e5b588e8646128e9a8b3f495c3897a5ce19592091a922ec7
7
- data.tar.gz: 604ff2aabe0ee95c8f7f748026baa9b9abda1ad6bea00ac698550c686a6d4bc73d962902c30b2d77e0000e7f19f6b1e2e664d7535e46183c1712891ccd7107b6
6
+ metadata.gz: 0ce1237c16d06a91eaee51646d421ead3cc6d7a3055a1b23783de7d6f51b55861006d9c06f0b54f66ae6061301ccd93a607102cdd4c55cc3a30b55e1bf82fc78
7
+ data.tar.gz: 79b4938554e3cf2cd8f61431016b432d415dfeacfa18650acce93486761b140d2cefc2b8b193c6852910e01fa51c734ee8e6805c0a4103a078a4a40ba64879ff
@@ -5,6 +5,7 @@ require "active_support"
5
5
  module MinatoLogger
6
6
  module Formatters
7
7
  class BaseFormatter < Logger::Formatter
8
+ include ActiveSupport::TaggedLogging::Formatter
8
9
  end
9
10
  end
10
11
  end
@@ -1,23 +1,42 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require "active_support/tagged_logging"
4
- require "google/cloud/trace"
5
3
  require "json"
6
4
 
7
5
  module MinatoLogger
8
6
  module Formatters
9
7
  class FluentBit < BaseFormatter
10
- include ActiveSupport::TaggedLogging::Formatter
11
-
12
8
  def call(severity, timestamp, _progname, message)
13
- log = add_message_to_logs({ severity: severity, time: timestamp }, message)
9
+ tagged_message = add_tags_to_message(message)
10
+ log = add_message_to_logs({ severity: severity, time: timestamp }, tagged_message)
14
11
  log = apply_middlewares(log)
15
12
 
16
- "#{log.to_json}\n"
13
+ sanitized_log = sanitize_hash(log)
14
+
15
+ "#{sanitized_log.to_json}\n"
17
16
  end
18
17
 
19
18
  private
20
19
 
20
+ def sanitize_hash(hash)
21
+ hash.transform_keys! { |key| key.to_s.encode("UTF-8", invalid: :replace, undef: :replace, replace: "?") }
22
+ hash.transform_values! do |value|
23
+ sanitize_hash_value(value)
24
+ end
25
+ end
26
+
27
+ def sanitize_hash_value(value)
28
+ case value
29
+ when String
30
+ value.encode("UTF-8", invalid: :replace, undef: :replace, replace: "?")
31
+ when Hash
32
+ sanitize_hash(value)
33
+ when Array
34
+ value.map { |v| v.is_a?(String) ? v.encode("UTF-8", invalid: :replace, undef: :replace, replace: "?") : v }
35
+ else
36
+ value
37
+ end
38
+ end
39
+
21
40
  def apply_middlewares(log)
22
41
  MinatoLogger.config.middleware.middlewares.each do |middleware|
23
42
  log = middleware.new.call(log)
@@ -31,6 +50,18 @@ module MinatoLogger
31
50
 
32
51
  log.merge({ message: message, ruby_version: RUBY_VERSION })
33
52
  end
53
+
54
+ def add_tags_to_message(msg)
55
+ return msg unless tags_text.present?
56
+
57
+ if msg.is_a?(Hash)
58
+ msg["message"] = "#{tags_text} #{msg["message"]}"
59
+ else
60
+ msg = "#{tags_text} #{msg}"
61
+ end
62
+
63
+ msg
64
+ end
34
65
  end
35
66
  end
36
67
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module MinatoLogger
4
- VERSION = "0.1.13-4"
4
+ VERSION = "0.1.13"
5
5
  end
@@ -31,7 +31,7 @@ Gem::Specification.new do |spec|
31
31
  spec.require_paths = ["lib"]
32
32
 
33
33
  spec.add_dependency "activesupport", "~> 7.0.4"
34
- spec.add_dependency "rails", ">= 7.0.0"
34
+ spec.add_dependency "rails", "~> 7.0", ">= 7.0.0"
35
35
  spec.add_dependency "stackdriver", "~> 0.21.1"
36
36
 
37
37
  # Uncomment to register a new dependency of your gem
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: minato_logger
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.13.pre.4
4
+ version: 0.1.13
5
5
  platform: ruby
6
6
  authors:
7
7
  - Ferreri
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2024-02-20 00:00:00.000000000 Z
11
+ date: 2025-03-14 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -28,6 +28,9 @@ dependencies:
28
28
  name: rails
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '7.0'
31
34
  - - ">="
32
35
  - !ruby/object:Gem::Version
33
36
  version: 7.0.0
@@ -35,6 +38,9 @@ dependencies:
35
38
  prerelease: false
36
39
  version_requirements: !ruby/object:Gem::Requirement
37
40
  requirements:
41
+ - - "~>"
42
+ - !ruby/object:Gem::Version
43
+ version: '7.0'
38
44
  - - ">="
39
45
  - !ruby/object:Gem::Version
40
46
  version: 7.0.0
@@ -99,11 +105,11 @@ required_ruby_version: !ruby/object:Gem::Requirement
99
105
  version: 2.6.0
100
106
  required_rubygems_version: !ruby/object:Gem::Requirement
101
107
  requirements:
102
- - - ">"
108
+ - - ">="
103
109
  - !ruby/object:Gem::Version
104
- version: 1.3.1
110
+ version: '0'
105
111
  requirements: []
106
- rubygems_version: 3.4.19
112
+ rubygems_version: 3.5.5
107
113
  signing_key:
108
114
  specification_version: 4
109
115
  summary: Log enhancements for Minato Rails Apps.