rack-potentially-secure-cookies 1.0.1

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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 097d2b73a2a3f4918b9c72fa010efc2eb931a25f
4
+ data.tar.gz: 4c1a16a283d75cfd097252b1c623aeec4a1da1a3
5
+ SHA512:
6
+ metadata.gz: 63d7f71c2f025c7c30bc1a5b39b7541c633192d12b10e99cf2fe85433877ea83736057eca7288965a936137cc050d721293d21a6c569f1a2dc6f8920d59185db
7
+ data.tar.gz: 38310b5cbe94927af0286ceb9aea34de8d00229dd0fa0fe68aa5fcb2c427d64d141b8cdd8736d3cd23e5a8e399143d30154cfa1c14939fd3b1bc9dc7088e9a28
data/MIT-LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright 2015 YOURNAME
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,44 @@
1
+ # Rack::PotentiallySecureCookie
2
+
3
+ This is a Rack middleware for one very specific purpose;
4
+
5
+ You have a site running on a server that can be accessed through both HTTP and
6
+ HTTPS. Whichever method the user accesses the site she'll never change. So if
7
+ you access the site the first time through HTTPS you will continue to do so.
8
+
9
+ Because security we needed a way to ensure that the cookie flag `Secure` was
10
+ being set whenever our users accesses the site through HTTPS, and to ensure it
11
+ was *not* set when accessing through HTTP as the users couldn't login then.
12
+
13
+ An example of this is:
14
+
15
+ * The site is running on a secured server deep in the middle of a datacenter
16
+ * This site serves the public internet and because of this there's SSL
17
+ termination in front of the site
18
+ * The same site is also being used internally at the company, under a split-view
19
+ setup and these users are not able to go through the SSL termination
20
+ * Since it would be wasteful to run the server with multiple instances of the
21
+ app only to configure the secure cookie setting something to dynamically set
22
+ this needed to be done
23
+
24
+ ## Installation and configuration
25
+
26
+ This is available as a gem so just add to your `Gemfile`:
27
+
28
+ ```ruby
29
+ gem 'rack-potentially-secure-cookies', require: 'rack/potentially_secure_cookies'
30
+ ```
31
+
32
+ In your `environment.rb` (or maybe `environments/production.rb`) add the middleware:
33
+
34
+ ```ruby
35
+ config.middleware.insert_before(ActionDispatch::Cookies,
36
+ Rack::PotentiallySecureCookies,
37
+ ['_session_id'])
38
+ ```
39
+
40
+ The last argument is an array of cookies to force this configuration on.
41
+
42
+ ## License
43
+
44
+ MIT License
data/Rakefile ADDED
@@ -0,0 +1,13 @@
1
+ begin
2
+ require 'bundler/setup'
3
+ rescue LoadError
4
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
5
+ end
6
+ require 'rspec/core/rake_task'
7
+
8
+ Bundler::GemHelper.install_tasks
9
+
10
+ RSpec::Core::RakeTask.new(:spec) do |t|
11
+ t.rspec_opts = '--format documentation'
12
+ end
13
+ task :default => :spec
@@ -0,0 +1,33 @@
1
+ module Rack
2
+ class PotentiallySecureCookies
3
+ VERSION = '1.0.1'
4
+
5
+ def initialize(app, cookies)
6
+ @app = app
7
+
8
+ # All in the name to make this as fast as possible anything that
9
+ # could be used in multiple requests have been defined here.
10
+ _cookies = "^((#{cookies.join(')|(')}))".freeze
11
+ @configured_cookies = /#{_cookies}/
12
+ @cookies_with_secure = /(#{_cookies}.*?)(; [Ss]ecure)(.*)$/
13
+ @cookies_without_secure = /(#{_cookies}(?!.*[Ss]ecure).*)/
14
+ @secure = /; [Ss]ecure/
15
+ end
16
+
17
+ def call(env)
18
+ status, headers, body = @app.call(env)
19
+
20
+ if headers['Set-Cookie'] && @configured_cookies.match(headers['Set-Cookie'])
21
+ request = Rack::Request.new(env)
22
+
23
+ if request.ssl?
24
+ headers['Set-Cookie'].gsub!(@cookies_without_secure, '\1; Secure')
25
+ else
26
+ headers['Set-Cookie'].gsub!(@cookies_with_secure, '\1\3')
27
+ end
28
+ end
29
+
30
+ [status, headers, body]
31
+ end
32
+ end
33
+ end
metadata ADDED
@@ -0,0 +1,63 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rack-potentially-secure-cookies
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Björn Andersson
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-12-10 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rack
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ description:
28
+ email:
29
+ - ba@sanitarium.se
30
+ executables: []
31
+ extensions: []
32
+ extra_rdoc_files: []
33
+ files:
34
+ - MIT-LICENSE
35
+ - README.md
36
+ - Rakefile
37
+ - lib/rack/potentially_secure_cookies.rb
38
+ homepage: https://github.com/gaqzi/rack-potentially-secure-cookies
39
+ licenses:
40
+ - MIT
41
+ metadata: {}
42
+ post_install_message:
43
+ rdoc_options: []
44
+ require_paths:
45
+ - lib
46
+ required_ruby_version: !ruby/object:Gem::Requirement
47
+ requirements:
48
+ - - ">="
49
+ - !ruby/object:Gem::Version
50
+ version: '0'
51
+ required_rubygems_version: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - ">="
54
+ - !ruby/object:Gem::Version
55
+ version: '0'
56
+ requirements: []
57
+ rubyforge_project:
58
+ rubygems_version: 2.2.5
59
+ signing_key:
60
+ specification_version: 4
61
+ summary: Force the secure bit of a cookie depending on whether your connection is
62
+ secure
63
+ test_files: []