minato_logger 0.2.0 → 0.2.1

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: 4afbd48d4b06b9bb97827f22beadd610cde65f37520d4fdd30b9eb11f3316f19
4
- data.tar.gz: 1d811dcb2e2fd85cdd83f7dc39346b30b7918417df0e240d3d4cd5ec3c2e5ad5
3
+ metadata.gz: 534bf4054eec92bbdf14f7478f412f777b85b112421828ebcddad95ac7fc52cd
4
+ data.tar.gz: 7c6c59e86c59b7c6366c8bb7872b16c01ec90aaf628b77f1d0494fe3f7ef83f8
5
5
  SHA512:
6
- metadata.gz: 1f3fc170a03319849e5e66c728054a4266401381c505e3fe489fe3a570c35afcd9a63acaeeab9b2eee571d7b6978e61ecc713f5b411921dc55c6c5f7cd97cae6
7
- data.tar.gz: fe41eecdf8aba5bfb19507c82c2e85da20063e3349a8ebc6c489705867eafa422c9a75f7f4738e2911729a8822bdc2884bb4f4045ae83da2320853f3a3f88230
6
+ metadata.gz: 38f0ec9350ede178fe175dde449fa5a6942c896b3e9984c0ac92c906ef38bb00c4df9928132b06d10cec78322de6b5e6ffcf53f47b5f45f8f5aee4a884408eed
7
+ data.tar.gz: 46e4660bd783baf64564f6c9bdb728b631ec23ea9c94aa49670c25d392c7e900074d5b07611550730f7be8319db603c1cc49005164b5ab64c6121dc402eb57bd
@@ -10,11 +10,33 @@ module MinatoLogger
10
10
  log = add_message_to_logs({ severity: severity, time: timestamp }, tagged_message)
11
11
  log = apply_middlewares(log)
12
12
 
13
- "#{log.to_json}\n"
13
+ sanitized_log = sanitize_hash(log)
14
+
15
+ "#{sanitized_log.to_json}\n"
14
16
  end
15
17
 
16
18
  private
17
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
+
18
40
  def apply_middlewares(log)
19
41
  MinatoLogger.config.middleware.middlewares.each do |middleware|
20
42
  log = middleware.new.call(log)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module MinatoLogger
4
- VERSION = "0.2.0"
4
+ VERSION = "0.2.1"
5
5
  end
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.2.0
4
+ version: 0.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Ferreri
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2024-12-31 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