api-auth 1.2.0 → 1.2.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.travis.yml +3 -0
- data/Appraisals +6 -0
- data/CHANGELOG.md +6 -0
- data/Gemfile.lock +1 -1
- data/VERSION +1 -1
- data/gemfiles/rails_23.gemfile +3 -1
- data/gemfiles/rails_23.gemfile.lock +1 -1
- data/gemfiles/rails_30.gemfile +3 -1
- data/gemfiles/rails_30.gemfile.lock +1 -1
- data/gemfiles/rails_31.gemfile.lock +1 -1
- data/gemfiles/rails_32.gemfile.lock +1 -1
- data/gemfiles/rails_4.gemfile.lock +1 -1
- data/gemfiles/rails_41.gemfile +9 -0
- data/gemfiles/rails_41.gemfile.lock +85 -0
- data/lib/api_auth/headers.rb +32 -27
- data/lib/api_auth/request_drivers/rest_client.rb +1 -0
- data/spec/api_auth_spec.rb +20 -0
- metadata +17 -37
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: e56cb7a8470464f1c066a02ad4caeb9864c612cb
|
4
|
+
data.tar.gz: b343e1646d443bed40bb7513efd85f76cb806297
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: b04802be5d905287f2948f8a3b1b712faf77ac722e479f3e20088279797e0f70589b822883c36749d54c590ff1a3f936d96c7dbed880f21e07063440ed8d9b1d
|
7
|
+
data.tar.gz: 27709d13a88f750aecd9495a4d617d1608d1c751ef41fbe69d2c9f950d54a4f7041920d7c6724d1b3698b172fd2d2852541e886a07732be965426aec7b0cc664
|
data/.travis.yml
CHANGED
@@ -8,10 +8,13 @@ gemfile:
|
|
8
8
|
- gemfiles/rails_31.gemfile
|
9
9
|
- gemfiles/rails_32.gemfile
|
10
10
|
- gemfiles/rails_4.gemfile
|
11
|
+
- gemfiles/rails_41.gemfile
|
11
12
|
matrix:
|
12
13
|
exclude:
|
13
14
|
- rvm: 1.8.7-p374
|
14
15
|
gemfile: gemfiles/rails_4.gemfile
|
16
|
+
- rvm: 1.8.7-p374
|
17
|
+
gemfile: gemfiles/rails_41.gemfile
|
15
18
|
|
16
19
|
notifications:
|
17
20
|
email: false
|
data/Appraisals
CHANGED
data/CHANGELOG.md
CHANGED
@@ -1,3 +1,9 @@
|
|
1
|
+
# 1.2.1 (2014-07-03)
|
2
|
+
|
3
|
+
- Fix Rest Client driver to account for the generated md5 when signing (#45 cjeeky)
|
4
|
+
- Support for testing against Rails 4.1 (#42 awendt)
|
5
|
+
- Support all requests inheriting from Rack::Request (#43 mcls)
|
6
|
+
|
1
7
|
# 1.2.0 (2014-05-16)
|
2
8
|
|
3
9
|
- Fix ruby 1.8.7 support
|
data/Gemfile.lock
CHANGED
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
1.2.
|
1
|
+
1.2.1
|
data/gemfiles/rails_23.gemfile
CHANGED
data/gemfiles/rails_30.gemfile
CHANGED
@@ -0,0 +1,85 @@
|
|
1
|
+
PATH
|
2
|
+
remote: ../
|
3
|
+
specs:
|
4
|
+
api-auth (1.2.1)
|
5
|
+
|
6
|
+
GEM
|
7
|
+
remote: https://rubygems.org/
|
8
|
+
specs:
|
9
|
+
actionpack (4.1.1)
|
10
|
+
actionview (= 4.1.1)
|
11
|
+
activesupport (= 4.1.1)
|
12
|
+
rack (~> 1.5.2)
|
13
|
+
rack-test (~> 0.6.2)
|
14
|
+
actionview (4.1.1)
|
15
|
+
activesupport (= 4.1.1)
|
16
|
+
builder (~> 3.1)
|
17
|
+
erubis (~> 2.7.0)
|
18
|
+
activemodel (4.1.1)
|
19
|
+
activesupport (= 4.1.1)
|
20
|
+
builder (~> 3.1)
|
21
|
+
activeresource (4.0.0)
|
22
|
+
activemodel (~> 4.0)
|
23
|
+
activesupport (~> 4.0)
|
24
|
+
rails-observers (~> 0.1.1)
|
25
|
+
activesupport (4.1.1)
|
26
|
+
i18n (~> 0.6, >= 0.6.9)
|
27
|
+
json (~> 1.7, >= 1.7.7)
|
28
|
+
minitest (~> 5.1)
|
29
|
+
thread_safe (~> 0.1)
|
30
|
+
tzinfo (~> 1.1)
|
31
|
+
amatch (0.3.0)
|
32
|
+
tins (~> 1.0)
|
33
|
+
appraisal (1.0.0)
|
34
|
+
bundler
|
35
|
+
rake
|
36
|
+
thor (>= 0.14.0)
|
37
|
+
builder (3.2.2)
|
38
|
+
curb (0.8.5)
|
39
|
+
diff-lcs (1.1.3)
|
40
|
+
erubis (2.7.0)
|
41
|
+
httpi (2.1.0)
|
42
|
+
rack
|
43
|
+
rubyntlm (~> 0.3.2)
|
44
|
+
i18n (0.6.9)
|
45
|
+
json (1.8.1)
|
46
|
+
mime-types (2.2)
|
47
|
+
minitest (5.3.4)
|
48
|
+
rack (1.5.2)
|
49
|
+
rack-test (0.6.2)
|
50
|
+
rack (>= 1.0)
|
51
|
+
rails-observers (0.1.2)
|
52
|
+
activemodel (~> 4.0)
|
53
|
+
rake (10.3.2)
|
54
|
+
rest-client (1.6.7)
|
55
|
+
mime-types (>= 1.16)
|
56
|
+
rspec (2.4.0)
|
57
|
+
rspec-core (~> 2.4.0)
|
58
|
+
rspec-expectations (~> 2.4.0)
|
59
|
+
rspec-mocks (~> 2.4.0)
|
60
|
+
rspec-core (2.4.0)
|
61
|
+
rspec-expectations (2.4.0)
|
62
|
+
diff-lcs (~> 1.1.2)
|
63
|
+
rspec-mocks (2.4.0)
|
64
|
+
rubyntlm (0.3.4)
|
65
|
+
thor (0.19.1)
|
66
|
+
thread_safe (0.3.3)
|
67
|
+
tins (1.3.0)
|
68
|
+
tzinfo (1.1.0)
|
69
|
+
thread_safe (~> 0.1)
|
70
|
+
|
71
|
+
PLATFORMS
|
72
|
+
ruby
|
73
|
+
|
74
|
+
DEPENDENCIES
|
75
|
+
actionpack (~> 4.1.0)
|
76
|
+
activeresource (~> 4.0.0)
|
77
|
+
activesupport (~> 4.1.0)
|
78
|
+
amatch
|
79
|
+
api-auth!
|
80
|
+
appraisal
|
81
|
+
curb (~> 0.8.1)
|
82
|
+
httpi
|
83
|
+
rake
|
84
|
+
rest-client (~> 1.6.0)
|
85
|
+
rspec (~> 2.4.0)
|
data/lib/api_auth/headers.rb
CHANGED
@@ -7,37 +7,42 @@ module ApiAuth
|
|
7
7
|
|
8
8
|
def initialize(request)
|
9
9
|
@original_request = request
|
10
|
+
@request = initialize_request_driver(request)
|
11
|
+
true
|
12
|
+
end
|
10
13
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
14
|
+
def initialize_request_driver(request)
|
15
|
+
new_request =
|
16
|
+
case request.class.to_s
|
17
|
+
when /Net::HTTP/
|
18
|
+
NetHttpRequest.new(request)
|
19
|
+
when /RestClient/
|
20
|
+
RestClientRequest.new(request)
|
21
|
+
when /Curl::Easy/
|
22
|
+
CurbRequest.new(request)
|
23
|
+
when /ActionController::Request/
|
24
|
+
ActionControllerRequest.new(request)
|
25
|
+
when /ActionController::TestRequest/
|
26
|
+
if defined?(ActionDispatch)
|
27
|
+
ActionDispatchRequest.new(request)
|
28
|
+
else
|
29
|
+
ActionControllerRequest.new(request)
|
30
|
+
end
|
31
|
+
when /ActionDispatch::Request/
|
32
|
+
ActionDispatchRequest.new(request)
|
33
|
+
when /ActionController::CgiRequest/
|
34
|
+
ActionControllerRequest.new(request)
|
35
|
+
when /HTTPI::Request/
|
36
|
+
HttpiRequest.new(request)
|
23
37
|
else
|
24
|
-
|
38
|
+
nil
|
25
39
|
end
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
when /ActionController::CgiRequest/
|
31
|
-
@request = ActionControllerRequest.new(request)
|
32
|
-
when /HTTPI::Request/
|
33
|
-
@request = HttpiRequest.new(request)
|
34
|
-
when /Sinatra::Request/
|
35
|
-
@request = RackRequest.new(request)
|
36
|
-
else
|
37
|
-
raise UnknownHTTPRequest, "#{request.class.to_s} is not yet supported."
|
38
|
-
end
|
39
|
-
true
|
40
|
+
|
41
|
+
return new_request if new_request
|
42
|
+
return RackRequest.new(request) if request.kind_of?(Rack::Request)
|
43
|
+
raise UnknownHTTPRequest, "#{request.class.to_s} is not yet supported."
|
40
44
|
end
|
45
|
+
private :initialize_request_driver
|
41
46
|
|
42
47
|
# Returns the request timestamp
|
43
48
|
def timestamp
|
data/spec/api_auth_spec.rb
CHANGED
@@ -155,6 +155,26 @@ describe "ApiAuth" do
|
|
155
155
|
@signed_request.headers['Authorization'].should == "APIAuth 1044:#{hmac(@secret_key, @request)}"
|
156
156
|
end
|
157
157
|
|
158
|
+
it "should sign the request using the generated md5 header" do
|
159
|
+
date = Time.now.utc.httpdate
|
160
|
+
headers1 = { 'Content-MD5' => "1B2M2Y8AsgTpgAmY7PhCfg==",
|
161
|
+
'Content-Type' => "text/plain",
|
162
|
+
'Date' => date }
|
163
|
+
request1 = RestClient::Request.new(:url => "/resource.xml?foo=bar&bar=foo",
|
164
|
+
:headers => headers1,
|
165
|
+
:method => :put)
|
166
|
+
headers2 = { 'Content-Type' => "text/plain",
|
167
|
+
'Date' => date }
|
168
|
+
request2 = RestClient::Request.new(:url => "/resource.xml?foo=bar&bar=foo",
|
169
|
+
:headers => headers2,
|
170
|
+
:method => :put)
|
171
|
+
|
172
|
+
ApiAuth.sign!(request1, @access_id, @secret_key)
|
173
|
+
ApiAuth.sign!(request2, @access_id, @secret_key)
|
174
|
+
|
175
|
+
request2.headers['Authorization'].should == request1.headers['Authorization']
|
176
|
+
end
|
177
|
+
|
158
178
|
it "should authenticate a valid request" do
|
159
179
|
ApiAuth.authentic?(@signed_request, @secret_key).should be_true
|
160
180
|
end
|
metadata
CHANGED
@@ -1,68 +1,60 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: api-auth
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.2.
|
5
|
-
prerelease:
|
4
|
+
version: 1.2.1
|
6
5
|
platform: ruby
|
7
6
|
authors:
|
8
7
|
- Mauricio Gomes
|
9
8
|
autorequire:
|
10
9
|
bindir: bin
|
11
10
|
cert_chain: []
|
12
|
-
date: 2014-
|
11
|
+
date: 2014-07-03 00:00:00.000000000 Z
|
13
12
|
dependencies:
|
14
13
|
- !ruby/object:Gem::Dependency
|
15
14
|
name: appraisal
|
16
15
|
requirement: !ruby/object:Gem::Requirement
|
17
|
-
none: false
|
18
16
|
requirements:
|
19
|
-
- -
|
17
|
+
- - '>='
|
20
18
|
- !ruby/object:Gem::Version
|
21
19
|
version: '0'
|
22
20
|
type: :development
|
23
21
|
prerelease: false
|
24
22
|
version_requirements: !ruby/object:Gem::Requirement
|
25
|
-
none: false
|
26
23
|
requirements:
|
27
|
-
- -
|
24
|
+
- - '>='
|
28
25
|
- !ruby/object:Gem::Version
|
29
26
|
version: '0'
|
30
27
|
- !ruby/object:Gem::Dependency
|
31
28
|
name: rake
|
32
29
|
requirement: !ruby/object:Gem::Requirement
|
33
|
-
none: false
|
34
30
|
requirements:
|
35
|
-
- -
|
31
|
+
- - '>='
|
36
32
|
- !ruby/object:Gem::Version
|
37
33
|
version: '0'
|
38
34
|
type: :development
|
39
35
|
prerelease: false
|
40
36
|
version_requirements: !ruby/object:Gem::Requirement
|
41
|
-
none: false
|
42
37
|
requirements:
|
43
|
-
- -
|
38
|
+
- - '>='
|
44
39
|
- !ruby/object:Gem::Version
|
45
40
|
version: '0'
|
46
41
|
- !ruby/object:Gem::Dependency
|
47
42
|
name: amatch
|
48
43
|
requirement: !ruby/object:Gem::Requirement
|
49
|
-
none: false
|
50
44
|
requirements:
|
51
|
-
- -
|
45
|
+
- - '>='
|
52
46
|
- !ruby/object:Gem::Version
|
53
47
|
version: '0'
|
54
48
|
type: :development
|
55
49
|
prerelease: false
|
56
50
|
version_requirements: !ruby/object:Gem::Requirement
|
57
|
-
none: false
|
58
51
|
requirements:
|
59
|
-
- -
|
52
|
+
- - '>='
|
60
53
|
- !ruby/object:Gem::Version
|
61
54
|
version: '0'
|
62
55
|
- !ruby/object:Gem::Dependency
|
63
56
|
name: rspec
|
64
57
|
requirement: !ruby/object:Gem::Requirement
|
65
|
-
none: false
|
66
58
|
requirements:
|
67
59
|
- - ~>
|
68
60
|
- !ruby/object:Gem::Version
|
@@ -70,7 +62,6 @@ dependencies:
|
|
70
62
|
type: :development
|
71
63
|
prerelease: false
|
72
64
|
version_requirements: !ruby/object:Gem::Requirement
|
73
|
-
none: false
|
74
65
|
requirements:
|
75
66
|
- - ~>
|
76
67
|
- !ruby/object:Gem::Version
|
@@ -78,7 +69,6 @@ dependencies:
|
|
78
69
|
- !ruby/object:Gem::Dependency
|
79
70
|
name: actionpack
|
80
71
|
requirement: !ruby/object:Gem::Requirement
|
81
|
-
none: false
|
82
72
|
requirements:
|
83
73
|
- - ~>
|
84
74
|
- !ruby/object:Gem::Version
|
@@ -86,7 +76,6 @@ dependencies:
|
|
86
76
|
type: :development
|
87
77
|
prerelease: false
|
88
78
|
version_requirements: !ruby/object:Gem::Requirement
|
89
|
-
none: false
|
90
79
|
requirements:
|
91
80
|
- - ~>
|
92
81
|
- !ruby/object:Gem::Version
|
@@ -94,7 +83,6 @@ dependencies:
|
|
94
83
|
- !ruby/object:Gem::Dependency
|
95
84
|
name: activesupport
|
96
85
|
requirement: !ruby/object:Gem::Requirement
|
97
|
-
none: false
|
98
86
|
requirements:
|
99
87
|
- - ~>
|
100
88
|
- !ruby/object:Gem::Version
|
@@ -102,7 +90,6 @@ dependencies:
|
|
102
90
|
type: :development
|
103
91
|
prerelease: false
|
104
92
|
version_requirements: !ruby/object:Gem::Requirement
|
105
|
-
none: false
|
106
93
|
requirements:
|
107
94
|
- - ~>
|
108
95
|
- !ruby/object:Gem::Version
|
@@ -110,7 +97,6 @@ dependencies:
|
|
110
97
|
- !ruby/object:Gem::Dependency
|
111
98
|
name: activeresource
|
112
99
|
requirement: !ruby/object:Gem::Requirement
|
113
|
-
none: false
|
114
100
|
requirements:
|
115
101
|
- - ~>
|
116
102
|
- !ruby/object:Gem::Version
|
@@ -118,7 +104,6 @@ dependencies:
|
|
118
104
|
type: :development
|
119
105
|
prerelease: false
|
120
106
|
version_requirements: !ruby/object:Gem::Requirement
|
121
|
-
none: false
|
122
107
|
requirements:
|
123
108
|
- - ~>
|
124
109
|
- !ruby/object:Gem::Version
|
@@ -126,7 +111,6 @@ dependencies:
|
|
126
111
|
- !ruby/object:Gem::Dependency
|
127
112
|
name: rest-client
|
128
113
|
requirement: !ruby/object:Gem::Requirement
|
129
|
-
none: false
|
130
114
|
requirements:
|
131
115
|
- - ~>
|
132
116
|
- !ruby/object:Gem::Version
|
@@ -134,7 +118,6 @@ dependencies:
|
|
134
118
|
type: :development
|
135
119
|
prerelease: false
|
136
120
|
version_requirements: !ruby/object:Gem::Requirement
|
137
|
-
none: false
|
138
121
|
requirements:
|
139
122
|
- - ~>
|
140
123
|
- !ruby/object:Gem::Version
|
@@ -142,7 +125,6 @@ dependencies:
|
|
142
125
|
- !ruby/object:Gem::Dependency
|
143
126
|
name: curb
|
144
127
|
requirement: !ruby/object:Gem::Requirement
|
145
|
-
none: false
|
146
128
|
requirements:
|
147
129
|
- - ~>
|
148
130
|
- !ruby/object:Gem::Version
|
@@ -150,7 +132,6 @@ dependencies:
|
|
150
132
|
type: :development
|
151
133
|
prerelease: false
|
152
134
|
version_requirements: !ruby/object:Gem::Requirement
|
153
|
-
none: false
|
154
135
|
requirements:
|
155
136
|
- - ~>
|
156
137
|
- !ruby/object:Gem::Version
|
@@ -158,17 +139,15 @@ dependencies:
|
|
158
139
|
- !ruby/object:Gem::Dependency
|
159
140
|
name: httpi
|
160
141
|
requirement: !ruby/object:Gem::Requirement
|
161
|
-
none: false
|
162
142
|
requirements:
|
163
|
-
- -
|
143
|
+
- - '>='
|
164
144
|
- !ruby/object:Gem::Version
|
165
145
|
version: '0'
|
166
146
|
type: :development
|
167
147
|
prerelease: false
|
168
148
|
version_requirements: !ruby/object:Gem::Requirement
|
169
|
-
none: false
|
170
149
|
requirements:
|
171
|
-
- -
|
150
|
+
- - '>='
|
172
151
|
- !ruby/object:Gem::Version
|
173
152
|
version: '0'
|
174
153
|
description: Full HMAC auth implementation for use in your gems and Rails apps.
|
@@ -200,6 +179,8 @@ files:
|
|
200
179
|
- gemfiles/rails_32.gemfile.lock
|
201
180
|
- gemfiles/rails_4.gemfile
|
202
181
|
- gemfiles/rails_4.gemfile.lock
|
182
|
+
- gemfiles/rails_41.gemfile
|
183
|
+
- gemfiles/rails_41.gemfile.lock
|
203
184
|
- lib/api-auth.rb
|
204
185
|
- lib/api_auth.rb
|
205
186
|
- lib/api_auth/base.rb
|
@@ -223,27 +204,26 @@ files:
|
|
223
204
|
- spec/test_helper.rb
|
224
205
|
homepage: https://github.com/mgomes/api_auth
|
225
206
|
licenses: []
|
207
|
+
metadata: {}
|
226
208
|
post_install_message:
|
227
209
|
rdoc_options: []
|
228
210
|
require_paths:
|
229
211
|
- lib
|
230
212
|
required_ruby_version: !ruby/object:Gem::Requirement
|
231
|
-
none: false
|
232
213
|
requirements:
|
233
|
-
- -
|
214
|
+
- - '>='
|
234
215
|
- !ruby/object:Gem::Version
|
235
216
|
version: '0'
|
236
217
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
237
|
-
none: false
|
238
218
|
requirements:
|
239
|
-
- -
|
219
|
+
- - '>='
|
240
220
|
- !ruby/object:Gem::Version
|
241
221
|
version: '0'
|
242
222
|
requirements: []
|
243
223
|
rubyforge_project:
|
244
|
-
rubygems_version:
|
224
|
+
rubygems_version: 2.0.14
|
245
225
|
signing_key:
|
246
|
-
specification_version:
|
226
|
+
specification_version: 4
|
247
227
|
summary: Simple HMAC authentication for your APIs
|
248
228
|
test_files:
|
249
229
|
- spec/api_auth_spec.rb
|