response_bank 1.3.5 → 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: b24a992a093711fd04ac8768221300e0c238a70b02ea40c49f87a3c05a1b87af
4
- data.tar.gz: 4665251a057b21f12858b55332f45e8be3587cc9aa787082be32df8082971256
3
+ metadata.gz: 0a5c7a799e1272fffad4878273bf154c09f809059944dbf47bf6c6c83d1b4acb
4
+ data.tar.gz: ff7a669443427dcee35c7d2a590258fc0ac0591bd156c1316a42198cacc4bd0e
5
5
  SHA512:
6
- metadata.gz: 834669e94059637b751b22783ad10c731b2a327f83bc1448e13d26532506bdb55145b6c12eb29c49fc635cf3cacdc9d6b5cad7c1e62af99000330b5b77e72c5c
7
- data.tar.gz: c6dccc62b543bef77132a8cfa1de1608c8a32db5abb9c610d71c743e8b94538e079d132f70b90bfb18addf0181f3c1627bd73a45c8e727532a7378cfd7d9399a
6
+ metadata.gz: 5ddaeeca4364360ce6f2392d5b53d2f34421e44a62f1184d594add38dc45ebf23f72184bc9aa097667404c83d6b64c450b91b1dd25726a307ba41149b8a9509d
7
+ data.tar.gz: 4bfc7ebc29beab0c67f72e24e635d9fa2a0ca59a06fd92027d00172acc31a1974288adee1a97baf005e2ae64751a49e205a7005c70881f27e44b03a6827bf66a
@@ -4,7 +4,7 @@ module ResponseBank
4
4
  class Middleware
5
5
  # Limit the cached headers
6
6
  # TODO: Make this lowercase/case-insentitive as per rfc2616 §4.2
7
- CACHEABLE_HEADERS = ["Location", "Content-Type", "ETag", "Content-Encoding", "Last-Modified", "Cache-Control", "Expires", "Link", "Surrogate-Keys", "Cache-Tags"].freeze
7
+ CACHEABLE_HEADERS = ["Location", "Content-Type", "ETag", "Content-Encoding", "Last-Modified", "Cache-Control", "Expires", "Link", "Surrogate-Keys", "Cache-Tags", "Speculation-Rules"].freeze
8
8
 
9
9
  REQUESTED_WITH = "HTTP_X_REQUESTED_WITH"
10
10
  ACCEPT = "HTTP_ACCEPT"
@@ -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.5"
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,15 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: response_bank
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.5
4
+ version: 1.3.7
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tobias Lütke
8
8
  - Burke Libbey
9
- autorequire:
10
9
  bindir: bin
11
10
  cert_chain: []
12
- date: 2024-01-17 00:00:00.000000000 Z
11
+ date: 1980-01-02 00:00:00.000000000 Z
13
12
  dependencies:
14
13
  - !ruby/object:Gem::Dependency
15
14
  name: msgpack
@@ -45,28 +44,28 @@ dependencies:
45
44
  requirements:
46
45
  - - ">="
47
46
  - !ruby/object:Gem::Version
48
- version: 5.18.0
47
+ version: '0'
49
48
  type: :development
50
49
  prerelease: false
51
50
  version_requirements: !ruby/object:Gem::Requirement
52
51
  requirements:
53
52
  - - ">="
54
53
  - !ruby/object:Gem::Version
55
- version: 5.18.0
54
+ version: '0'
56
55
  - !ruby/object:Gem::Dependency
57
56
  name: mocha
58
57
  requirement: !ruby/object:Gem::Requirement
59
58
  requirements:
60
59
  - - ">="
61
60
  - !ruby/object:Gem::Version
62
- version: 2.0.0
61
+ version: '0'
63
62
  type: :development
64
63
  prerelease: false
65
64
  version_requirements: !ruby/object:Gem::Requirement
66
65
  requirements:
67
66
  - - ">="
68
67
  - !ruby/object:Gem::Version
69
- version: 2.0.0
68
+ version: '0'
70
69
  - !ruby/object:Gem::Dependency
71
70
  name: rake
72
71
  requirement: !ruby/object:Gem::Requirement
@@ -87,16 +86,16 @@ dependencies:
87
86
  requirements:
88
87
  - - ">="
89
88
  - !ruby/object:Gem::Version
90
- version: '6.1'
89
+ version: '0'
91
90
  type: :development
92
91
  prerelease: false
93
92
  version_requirements: !ruby/object:Gem::Requirement
94
93
  requirements:
95
94
  - - ">="
96
95
  - !ruby/object:Gem::Version
97
- version: '6.1'
96
+ version: '0'
98
97
  - !ruby/object:Gem::Dependency
99
- name: pry
98
+ name: simplecov
100
99
  requirement: !ruby/object:Gem::Requirement
101
100
  requirements:
102
101
  - - ">="
@@ -109,7 +108,6 @@ dependencies:
109
108
  - - ">="
110
109
  - !ruby/object:Gem::Version
111
110
  version: '0'
112
- description:
113
111
  email:
114
112
  - tobi@shopify.com
115
113
  - burke@burkelibbey.org
@@ -131,7 +129,6 @@ licenses:
131
129
  - MIT
132
130
  metadata:
133
131
  allowed_push_host: https://rubygems.org
134
- post_install_message:
135
132
  rdoc_options: []
136
133
  require_paths:
137
134
  - lib
@@ -146,8 +143,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
146
143
  - !ruby/object:Gem::Version
147
144
  version: '0'
148
145
  requirements: []
149
- rubygems_version: 3.5.4
150
- signing_key:
146
+ rubygems_version: 3.7.2
151
147
  specification_version: 4
152
148
  summary: Simple response caching for Ruby applications
153
149
  test_files: []