response_bank 1.3.6 → 1.3.7

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: 59df27c0628e98bd29533d141d2209e03ab602ccc7a87f7cb4b74b6a6a671852
4
- data.tar.gz: 955d472d29e0827203634443e9341f67f24cfcdf61b8f152bb0e8564732ede7f
3
+ metadata.gz: 0a5c7a799e1272fffad4878273bf154c09f809059944dbf47bf6c6c83d1b4acb
4
+ data.tar.gz: ff7a669443427dcee35c7d2a590258fc0ac0591bd156c1316a42198cacc4bd0e
5
5
  SHA512:
6
- metadata.gz: 6cbc80643e1eaed0a3f7a039b3b30f02cb56a245ece87549dd29948c3e959c1aaefb4ef870a163ebab20bc6dd4a959a790881f4441703f1ee60cf11ca16f35cf
7
- data.tar.gz: f949480d70681d20537ab03b766c7dfdf4cfbaa6f70aa2965a87e219e47bc6aab532d26e32675d3fb5f45f20f41822a8878519f6e020b905ff1a477fbd839fc7
6
+ metadata.gz: 5ddaeeca4364360ce6f2392d5b53d2f34421e44a62f1184d594add38dc45ebf23f72184bc9aa097667404c83d6b64c450b91b1dd25726a307ba41149b8a9509d
7
+ data.tar.gz: 4bfc7ebc29beab0c67f72e24e635d9fa2a0ca59a06fd92027d00172acc31a1974288adee1a97baf005e2ae64751a49e205a7005c70881f27e44b03a6827bf66a
@@ -37,12 +37,21 @@ module ResponseBank
37
37
  body_compressed = nil
38
38
  if body_string && body_string != ""
39
39
  headers['Content-Encoding'] = content_encoding
40
- body_compressed = ResponseBank.compress(body_string, content_encoding)
40
+ env["cacheable.compression_level"] = ResponseBank.compression_level_for_request(env, headers)
41
+ time = ResponseBank.measure do
42
+ body_compressed = ResponseBank.compress(
43
+ body_string,
44
+ content_encoding,
45
+ compression_level: env["cacheable.compression_level"],
46
+ )
47
+ end
48
+ ResponseBank.log("Compression time: #{time}ms")
49
+ env["cacheable.compression_time"] = time
41
50
  end
42
51
 
43
52
  cached_headers = headers.slice(*CACHEABLE_HEADERS)
44
53
  # Store result
45
- cache_data = [status, cached_headers, body_compressed, timestamp]
54
+ cache_data = [status, cached_headers, body_compressed, timestamp, env["cacheable.compression_level"]]
46
55
 
47
56
  ResponseBank.write_to_cache(env['cacheable.key']) do
48
57
  payload = MessagePack.dump(cache_data)
@@ -119,7 +119,9 @@ module ResponseBank
119
119
  @env['cacheable.miss'] = false
120
120
  @env['cacheable.store'] = 'server'
121
121
 
122
- status, headers, body, timestamp = hit
122
+ status, headers, body, timestamp, compression_level = hit
123
+
124
+ @env['cacheable.compression_level'] = compression_level
123
125
 
124
126
  @env['cacheable.locked'] ||= false
125
127
 
@@ -1,4 +1,4 @@
1
1
  # frozen_string_literal: true
2
2
  module ResponseBank
3
- VERSION = "1.3.6"
3
+ VERSION = "1.3.7"
4
4
  end
data/lib/response_bank.rb CHANGED
@@ -4,11 +4,31 @@ require 'response_bank/railtie' if defined?(Rails)
4
4
  require 'response_bank/response_cache_handler'
5
5
  require 'msgpack'
6
6
  require 'brotli'
7
+ require 'benchmark'
7
8
 
8
9
  module ResponseBank
9
10
  class << self
10
11
  attr_accessor :cache_store
11
- attr_writer :logger
12
+ attr_writer :logger, :compression_level
13
+
14
+ DEFAULT_BROTLI_COMPRESSION_LEVEL = 7
15
+
16
+ DEFAULT_COMPRESSION_LEVEL = -> (_env, headers) {
17
+ case headers['Content-Encoding']
18
+ when 'br'
19
+ DEFAULT_BROTLI_COMPRESSION_LEVEL
20
+ when 'gzip'
21
+ Zlib::BEST_COMPRESSION
22
+ end
23
+ }
24
+
25
+ def compression_level_for_request(env, headers)
26
+ if @compression_level
27
+ return @compression_level.respond_to?(:call) ? @compression_level.call(env, headers) : @compression_level
28
+ end
29
+
30
+ DEFAULT_COMPRESSION_LEVEL.call(env, headers)
31
+ end
12
32
 
13
33
  def log(message)
14
34
  @logger.info("[ResponseBank] #{message}")
@@ -30,13 +50,19 @@ module ResponseBank
30
50
  backing_cache_store.read(cache_key, raw: true)
31
51
  end
32
52
 
33
- def compress(content, encoding = "br")
53
+ def measure
54
+ Benchmark.realtime do
55
+ yield
56
+ end * 1000 # milliseconds
57
+ end
58
+
59
+ def compress(content, encoding = "br", compression_level: nil)
34
60
  case encoding
35
61
  when 'gzip'
36
62
  attempts = 0
37
63
 
38
64
  begin
39
- Zlib.gzip(content, level: Zlib::BEST_COMPRESSION)
65
+ Zlib.gzip(content, level: compression_level || Zlib::BEST_COMPRESSION)
40
66
  rescue Zlib::BufError
41
67
  # We get sporadic Zlib::BufError, so we retry once (https://github.com/ruby/zlib/issues/49)
42
68
  attempts += 1
@@ -48,7 +74,7 @@ module ResponseBank
48
74
  end
49
75
  end
50
76
  when 'br'
51
- Brotli.deflate(content, mode: :text, quality: 7)
77
+ Brotli.deflate(content, mode: :text, quality: compression_level || DEFAULT_BROTLI_COMPRESSION_LEVEL)
52
78
  else
53
79
  raise ArgumentError, "Unsupported encoding: #{encoding}"
54
80
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: response_bank
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.6
4
+ version: 1.3.7
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tobias Lütke
@@ -143,7 +143,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
143
143
  - !ruby/object:Gem::Version
144
144
  version: '0'
145
145
  requirements: []
146
- rubygems_version: 3.6.9
146
+ rubygems_version: 3.7.2
147
147
  specification_version: 4
148
148
  summary: Simple response caching for Ruby applications
149
149
  test_files: []