minato_logger 0.1.13.pre.5 → 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: 7673fcdba540e6485a39fccf31e2bd4ede8239b07ba7d0555c972f8dcb56f77e
4
- data.tar.gz: a338ab6a4d99d3ba5efdbf706d2c68f2641adaca413d0517cfab57864c84578e
3
+ metadata.gz: e7f37f246b04ca0fb8200abd73730c82c7acd74e377a092241a7a9c4b81c432a
4
+ data.tar.gz: e9900da1f8a50a21c5f52ea1d6313394201256b2c9740d032777e8201da25307
5
5
  SHA512:
6
- metadata.gz: 45f4a901a5be41467bc4a94138a743fbd2775dcc518ef1bdfc72b171b8ee9d6b7663e11f5b3615247e016361487d54f4555df7077c413d372953ae84ed666ea1
7
- data.tar.gz: 6d4537ff78aaeba4aab55a963a5ddf5860dfe9870a60c935c244513a70ec2b3c006ec52342aef4d762840b60d5c74a582ba3a42448745588c580365ec034a1be
6
+ metadata.gz: 0ce1237c16d06a91eaee51646d421ead3cc6d7a3055a1b23783de7d6f51b55861006d9c06f0b54f66ae6061301ccd93a607102cdd4c55cc3a30b55e1bf82fc78
7
+ data.tar.gz: 79b4938554e3cf2cd8f61431016b432d415dfeacfa18650acce93486761b140d2cefc2b8b193c6852910e01fa51c734ee8e6805c0a4103a078a4a40ba64879ff
@@ -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.1.13-5"
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.5
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-03-01 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.