subdomainbox 0.6.0 → 0.7.0
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.
- data/VERSION +1 -1
- data/lib/subdomainbox/secure_csrf_token.rb +1 -1
- data/spec/secure_csrf_token_spec.rb +9 -13
- data/subdomainbox.gemspec +1 -1
- metadata +14 -14
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.
|
1
|
+
0.7.0
|
@@ -10,7 +10,7 @@ module ActionController #:nodoc:
|
|
10
10
|
# Sets the token value for the current session.
|
11
11
|
def form_authenticity_token
|
12
12
|
raise 'CSRF token secret must be defined' if CSRF_TOKEN_SECRET.nil? || CSRF_TOKEN_SECRET.empty?
|
13
|
-
if
|
13
|
+
if request.session_options[:id].nil? || request.session_options[:id].empty?
|
14
14
|
original_form_authenticity_token
|
15
15
|
else
|
16
16
|
Digest::SHA1.hexdigest("#{CSRF_TOKEN_SECRET}#{request.session_options[:id]}#{request.subdomain}")
|
@@ -22,23 +22,11 @@ describe "ActionController::RequestForgeryProtection" do
|
|
22
22
|
end
|
23
23
|
|
24
24
|
context "when the user has a session" do
|
25
|
-
before(:each) do
|
26
|
-
request.stub_chain(:session_options, :[]).and_return('abc')
|
27
|
-
end
|
28
|
-
|
29
25
|
it "should be generated from the CSRF_TOKEN_SECRET salted with the session id and the subdomain" do
|
26
|
+
request.stub_chain(:session_options, :[]).and_return('abc')
|
30
27
|
CSRF_TOKEN_SECRET = 'xyz'
|
31
28
|
form_authenticity_token.should == Digest::SHA1.hexdigest('xyzabcpets')
|
32
29
|
end
|
33
|
-
|
34
|
-
context "when the default subdomainbox has been removed" do
|
35
|
-
it "should call the original form_authenticity_token" do
|
36
|
-
@default_subdomainbox_removed = true
|
37
|
-
self.should_receive(:original_form_authenticity_token)
|
38
|
-
form_authenticity_token
|
39
|
-
end
|
40
|
-
end
|
41
|
-
|
42
30
|
end
|
43
31
|
|
44
32
|
context "when there is no session id" do
|
@@ -49,6 +37,14 @@ describe "ActionController::RequestForgeryProtection" do
|
|
49
37
|
end
|
50
38
|
end
|
51
39
|
|
40
|
+
context "when there is an empty session id" do
|
41
|
+
it "should call the original form_authenticity_token" do
|
42
|
+
request.stub_chain(:session_options, :[]).and_return('')
|
43
|
+
self.should_receive(:original_form_authenticity_token)
|
44
|
+
form_authenticity_token
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
52
48
|
end
|
53
49
|
|
54
50
|
end
|
data/subdomainbox.gemspec
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: subdomainbox
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.7.0
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -13,7 +13,7 @@ date: 2013-05-02 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: uuidtools
|
16
|
-
requirement: &
|
16
|
+
requirement: &2160194860 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *2160194860
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: rspec
|
27
|
-
requirement: &
|
27
|
+
requirement: &2160213360 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - =
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: 2.10.0
|
33
33
|
type: :development
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *2160213360
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: jeweler
|
38
|
-
requirement: &
|
38
|
+
requirement: &2160212040 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ~>
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: 1.8.4
|
44
44
|
type: :development
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *2160212040
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: pry
|
49
|
-
requirement: &
|
49
|
+
requirement: &2160210100 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :development
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *2160210100
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: pry-nav
|
60
|
-
requirement: &
|
60
|
+
requirement: &2160208180 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :development
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *2160208180
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: pry-stack_explorer
|
71
|
-
requirement: &
|
71
|
+
requirement: &2160206540 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,7 +76,7 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :development
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *2160206540
|
80
80
|
description: use subdomains to prevent XSS from accessing your entire application
|
81
81
|
if it should happen to be injected into some page in your app
|
82
82
|
email: dnelson@centresource.com
|
@@ -118,7 +118,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
118
118
|
version: '0'
|
119
119
|
segments:
|
120
120
|
- 0
|
121
|
-
hash:
|
121
|
+
hash: 4123236881766374921
|
122
122
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
123
123
|
none: false
|
124
124
|
requirements:
|