fluent-plugin-fluent-plugin-json-size-limit 0.1.15 → 0.1.17
Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: be537cc111d37698e89d70b879e7188880ff47e9d271413c8bc71a96e11ced89
|
4
|
+
data.tar.gz: 0d063b8c88de22b7ab1f9aeeeba7367dffc8149165cb268f0889d023b26fbcb7
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c52de0d0a0aef5001d4cfa8eb1cd80ef4b145db0f3ca2347506721400c4ead8eec5381c49549cf3c9105338a356e29639f89b5061e2aca0485f43fbaae511fa3
|
7
|
+
data.tar.gz: faf75d84fa049f2688cca7d633112519a4a9af57dc20b6971101425fdbf67e93c9a74a03e34e9731ed21780df487c5fdee0797679ddd532270f1893c99ea75d2
|
@@ -3,7 +3,7 @@ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
|
3
3
|
|
4
4
|
Gem::Specification.new do |spec|
|
5
5
|
spec.name = "fluent-plugin-fluent-plugin-json-size-limit"
|
6
|
-
spec.version = "0.1.
|
6
|
+
spec.version = "0.1.17"
|
7
7
|
spec.authors = ["Mykola Panin"]
|
8
8
|
spec.email = ["mykola.panin@creatoriq.com"]
|
9
9
|
|
@@ -29,29 +29,37 @@ module Fluent
|
|
29
29
|
|
30
30
|
def filter(tag, time, record)
|
31
31
|
original_size = record.to_json.bytesize
|
32
|
-
|
32
|
+
reduce_size(record, @max_size)
|
33
|
+
final_size = record.to_json.bytesize
|
33
34
|
|
34
|
-
if
|
35
|
-
|
35
|
+
log.debug "Reduced record size from #{original_size} to #{final_size} bytes" if original_size != final_size
|
36
|
+
record
|
37
|
+
end
|
36
38
|
|
37
|
-
|
38
|
-
|
39
|
+
private
|
40
|
+
|
41
|
+
def reduce_size(obj, target_size)
|
42
|
+
json_str = obj.to_json
|
43
|
+
return if json_str.bytesize <= target_size
|
39
44
|
|
45
|
+
if obj.is_a?(Hash)
|
46
|
+
sorted_fields = obj.sort_by { |_, v| v.to_s.length }.reverse
|
47
|
+
sorted_fields.each do |key, value|
|
40
48
|
current_size = json_str.bytesize
|
41
|
-
excess_size = current_size -
|
49
|
+
excess_size = current_size - target_size
|
42
50
|
|
43
|
-
|
44
|
-
|
45
|
-
|
51
|
+
if value.is_a?(String) && value.length > 10
|
52
|
+
new_length = [value.length - excess_size, 0].max
|
53
|
+
obj[key] = value[0...new_length]
|
54
|
+
elsif value.is_a?(Hash) || value.is_a?(Array)
|
55
|
+
reduce_size(value, target_size)
|
56
|
+
end
|
46
57
|
|
47
|
-
break if
|
58
|
+
break if obj.to_json.bytesize <= target_size
|
48
59
|
end
|
49
|
-
|
50
|
-
|
51
|
-
log.debug "Reduced record size from #{original_size} to #{final_size} bytes"
|
60
|
+
elsif obj.is_a?(Array)
|
61
|
+
obj.each { |element| reduce_size(element, target_size) }
|
52
62
|
end
|
53
|
-
|
54
|
-
record
|
55
63
|
end
|
56
64
|
end
|
57
65
|
end
|