rails_same_site_cookie 0.1.9 → 0.1.10

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: de603a08185ff1e1df7e28ca0229d6a1f64474336788d233af3a0d647d028868
4
- data.tar.gz: f01fc02d4261a916c3b2776fa9bafee35a37d5d00c64592d8ecba0aba4a7def2
3
+ metadata.gz: d6fa81378a73177217ee8a6cf22b3393972b6f675a579eb72f9e76eeecd5274a
4
+ data.tar.gz: 1299774e31c995474be51d4bbe8926cc0f7b6a2cf6acf0864358d84e5d17f6aa
5
5
  SHA512:
6
- metadata.gz: 516d7d5d61abe352bcd927663aec93d85ea0ceffcf254b1816e64168fd627431398dd9a505f7bb4457d53ce093201260039079ef4c69c13739b18a575dbfe357
7
- data.tar.gz: 5aa26a4289c6fb3ece3b9438c8e4977dca23fa2cfc9eb4d91ba63a01ac44b969152f77f2de93f7c49864fda29fd9178d55b99172a76bc13479391d39bec51586
6
+ metadata.gz: '08900401473433c96bc4293cfee4ab587ceff0bced274314512408969c23e5b7a57ee6922d501f7dfeebbae0c16342ef12ceccd128252940802d8f29473e9151'
7
+ data.tar.gz: afa375b09d3f965bebff85cc2f3b7622600d8d86a89083c66bd5f6a5191ead709803a93e9d6ba7a3c7ca7ce9cabf72ed7ec8cd31bef3c6ec502d3b8dc0f799dc
data/README.md CHANGED
@@ -9,7 +9,7 @@ This new behavior shouldn't be a problem for most apps but if your Rails app pro
9
9
  This gem fixes the above problems by explicity setting SameSite=None for all cookies where the SameSite directive is missing and the requesting user agent is not in Chrome's [provided list of known incompatible clients](https://www.chromium.org/updates/same-site/incompatible-clients).
10
10
 
11
11
  ### Note about incompatibility with Safari and the future of third-party cookies
12
- Newer versions of Safari [block third party cookies by defaul](https://webkit.org/blog/10218/full-third-party-cookie-blocking-and-more/) regardless of whether the SameSite flag is set. By design there is no workaround for this without the user manually going in and overriding the default settings to allow cross-site tracking. Chrome also plans to [completely phase out third party cookies in 2022](https://blog.chromium.org/2020/01/building-more-private-web-path-towards.html) at which point this gem will be useless.
12
+ Newer versions of Safari [block third party cookies by default](https://webkit.org/blog/10218/full-third-party-cookie-blocking-and-more/) regardless of whether the SameSite flag is set. By design there is no workaround for this without the user manually going in and overriding the default settings to allow cross-site tracking. Chrome also plans to [completely phase out third party cookies in 2022](https://blog.chromium.org/2020/01/building-more-private-web-path-towards.html) at which point this gem will be useless.
13
13
 
14
14
  ### Note about HTTP requests and local testing
15
15
  Note that for Chrome/Chromium based browsers the gem only sets the SameSite flag on cookies sent over HTTPS. So if you're testing on your local machine and you haven't setup your localhost to use SSL you will see warnings in versions of Chrome less than 80 about the missing SameSite flag, and in Chrome 80+ these cookies will be ignored entirely. To work around this in Chrome 80+ without setting up SSL you can disable the following Chrome flags: chrome://flags/ -> `SameSite by default cookies` and `Cookies without SameSite must be secure`.
@@ -14,10 +14,11 @@ module RailsSameSiteCookie
14
14
 
15
15
  regex = RailsSameSiteCookie.configuration.user_agent_regex
16
16
  set_cookie = headers['Set-Cookie']
17
- if (regex.nil? or regex.match(env['HTTP_USER_AGENT'])) and not (set_cookie.nil? or set_cookie.strip == '')
17
+ set_cookie_is_array = set_cookie.is_a?(Array)
18
+ if (regex.nil? or regex.match(env['HTTP_USER_AGENT'])) and not (set_cookie.nil? or (set_cookie_is_array ? set_cookie.empty? : set_cookie.strip == ''))
18
19
  parser = UserAgentChecker.new(env['HTTP_USER_AGENT'])
19
20
  if parser.send_same_site_none?
20
- cookies = set_cookie.split(COOKIE_SEPARATOR)
21
+ cookies = set_cookie_is_array ? set_cookie : set_cookie.split(COOKIE_SEPARATOR)
21
22
  ssl = Rack::Request.new(env).ssl?
22
23
 
23
24
  cookies.each do |cookie|
@@ -34,7 +35,7 @@ module RailsSameSiteCookie
34
35
 
35
36
  end
36
37
 
37
- headers['Set-Cookie'] = cookies.join(COOKIE_SEPARATOR)
38
+ headers['Set-Cookie'] = set_cookie_is_array ? cookies : cookies.join(COOKIE_SEPARATOR)
38
39
  end
39
40
  end
40
41
 
@@ -42,4 +43,4 @@ module RailsSameSiteCookie
42
43
  end
43
44
 
44
45
  end
45
- end
46
+ end
@@ -1,3 +1,3 @@
1
1
  module RailsSameSiteCookie
2
- VERSION = "0.1.9"
2
+ VERSION = "0.1.10"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rails_same_site_cookie
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.9
4
+ version: 0.1.10
5
5
  platform: ruby
6
6
  authors:
7
7
  - Philip Schinis
8
- autorequire:
8
+ autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-09-24 00:00:00.000000000 Z
11
+ date: 2025-01-02 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -80,7 +80,7 @@ dependencies:
80
80
  - - "~>"
81
81
  - !ruby/object:Gem::Version
82
82
  version: '2.6'
83
- description:
83
+ description:
84
84
  email:
85
85
  - p.schinis@gmail.com
86
86
  executables: []
@@ -110,7 +110,7 @@ licenses:
110
110
  metadata:
111
111
  homepage_uri: https://github.com/pschinis/rails_same_site_cookie
112
112
  source_code_uri: https://github.com/pschinis/rails_same_site_cookie
113
- post_install_message:
113
+ post_install_message:
114
114
  rdoc_options: []
115
115
  require_paths:
116
116
  - lib
@@ -126,7 +126,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
126
126
  version: '0'
127
127
  requirements: []
128
128
  rubygems_version: 3.1.2
129
- signing_key:
129
+ signing_key:
130
130
  specification_version: 4
131
131
  summary: This gem allows you to set the SameSite=None cookie directive without breaking
132
132
  browsers that don't support it.