simple-api-auth 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (42) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +14 -0
  3. data/.rspec +3 -0
  4. data/.rubocop.yml +14 -0
  5. data/.ruby-version +1 -0
  6. data/.travis.yml +16 -0
  7. data/Gemfile +12 -0
  8. data/Guardfile +5 -0
  9. data/LICENSE +22 -0
  10. data/README.md +169 -0
  11. data/Rakefile +7 -0
  12. data/lib/simple-api-auth/authenticable.rb +72 -0
  13. data/lib/simple-api-auth/authenticator.rb +32 -0
  14. data/lib/simple-api-auth/config.rb +61 -0
  15. data/lib/simple-api-auth/hashers/sha1_hasher.rb +14 -0
  16. data/lib/simple-api-auth/helpers/auth_helpers.rb +49 -0
  17. data/lib/simple-api-auth/helpers/request_helpers.rb +18 -0
  18. data/lib/simple-api-auth/request.rb +34 -0
  19. data/lib/simple-api-auth/signer.rb +53 -0
  20. data/lib/simple-api-auth/version.rb +6 -0
  21. data/lib/simple-api-auth.rb +47 -0
  22. data/simple-api-auth.gemspec +25 -0
  23. data/spec/extensions/string_spec.rb +13 -0
  24. data/spec/internal/app/models/models.rb +13 -0
  25. data/spec/internal/config/database.yml +4 -0
  26. data/spec/internal/db/schema.rb +7 -0
  27. data/spec/lib/simple-api-auth/authenticable_spec.rb +106 -0
  28. data/spec/lib/simple-api-auth/authenticator_spec.rb +35 -0
  29. data/spec/lib/simple-api-auth/config_spec.rb +48 -0
  30. data/spec/lib/simple-api-auth/helpers/auth_helpers_spec.rb +61 -0
  31. data/spec/lib/simple-api-auth/helpers/request_helpers_spec.rb +39 -0
  32. data/spec/lib/simple-api-auth/request_spec.rb +49 -0
  33. data/spec/lib/simple-api-auth/signer_spec.rb +37 -0
  34. data/spec/lib/simple-api-auth_spec.rb +110 -0
  35. data/spec/spec_helper.rb +31 -0
  36. data/spec/support/auth.rb +13 -0
  37. data/spec/support/database.rb +14 -0
  38. data/spec/support/database_cleaner.rb +19 -0
  39. data/spec/support/extensions.rb +10 -0
  40. data/spec/support/mocks.rb +67 -0
  41. data/spec/support/requests.rb +51 -0
  42. metadata +189 -0
@@ -0,0 +1,67 @@
1
+ module SpecHelpers
2
+ module Dummy
3
+ def request_time
4
+ Time.utc(2014, 11, 8, 0, 6)
5
+ end
6
+
7
+ def outdated_time
8
+ Time.utc(2014, 11, 8, 0, 1)
9
+ end
10
+
11
+ def mock_secret_key
12
+ 'ultra_secret_key'
13
+ end
14
+
15
+ def mock_headers
16
+ {
17
+ 'Authorization' => 'Signature: dummy_signature',
18
+ 'X-Saa-Auth-Time' => request_time.iso8601,
19
+ 'X-Saa-Key' => 'user_personal_key'
20
+ }
21
+ end
22
+
23
+ def mock_hashed_request
24
+ Digest.hexencode(
25
+ <<-EOF.unindent[0..-2]
26
+ hashed:get
27
+ /foobar
28
+ foo=bar&baz=qux
29
+ #{Digest.hexencode('hashed:')}
30
+ EOF
31
+ )
32
+ end
33
+
34
+ def mock_string_to_sign
35
+ mock_headers['X-Saa-Auth-Time'] + "\n" + mock_hashed_request
36
+ end
37
+
38
+ def mock_signature
39
+ date = mock_request.time.strftime('%Y%m%d')
40
+ Digest.hexencode("ssa#{mock_secret_key}:#{date}:ssa_request:#{mock_string_to_sign}")
41
+ end
42
+
43
+ def setup_dummy_signer
44
+ signer = double
45
+ allow(signer).to receive(:sign) { 'dummy_signature' }
46
+ signer_class = double
47
+ allow(signer_class).to receive(:new) { signer }
48
+
49
+ SimpleApiAuth.configure do |config|
50
+ config.signer = signer_class
51
+ end
52
+ end
53
+
54
+ def rails_request
55
+ SpecHelpers::Requests::RailsRequest.new(
56
+ headers: mock_headers,
57
+ method: 'GET',
58
+ path: '/foobar',
59
+ query_string: 'foo=bar&baz=qux'
60
+ )
61
+ end
62
+
63
+ def mock_request
64
+ SimpleApiAuth::Request.create(rails_request)
65
+ end
66
+ end
67
+ end
@@ -0,0 +1,51 @@
1
+ module SpecHelpers
2
+ module Requests
3
+ class BaseRequest
4
+ DEFAULTS = {
5
+ path: '/',
6
+ query_string: '',
7
+ body: StringIO.new('')
8
+ }
9
+
10
+ attr_accessor :path, :query_string, :body
11
+
12
+ def initialize(options = {})
13
+ options = DEFAULTS.merge(options)
14
+ options.each do |k, v|
15
+ send("#{k}=", v)
16
+ end
17
+ end
18
+
19
+ def self.configure
20
+ end
21
+ end
22
+
23
+ class RailsRequest < BaseRequest
24
+ attr_accessor :headers, :method
25
+ end
26
+
27
+ class SinatraRequest < BaseRequest
28
+ attr_accessor :env, :request_method
29
+
30
+ def initialize(options = {})
31
+ options[:env] = options.delete :headers
32
+ options[:request_method] = options.delete :method
33
+ super
34
+ end
35
+
36
+ def self.configure
37
+ ::SimpleApiAuth.configure do |config|
38
+ config.request_fields[:headers] = :env
39
+ config.request_fields[:http_verb] = :request_method
40
+ end
41
+ end
42
+ end
43
+
44
+ def requests
45
+ {
46
+ 'rails request' => RailsRequest,
47
+ 'sinatra request' => SinatraRequest
48
+ }
49
+ end
50
+ end
51
+ end
metadata ADDED
@@ -0,0 +1,189 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: simple-api-auth
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Daniel Perez
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2014-11-09 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rake
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '10.0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '10.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rspec
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '3.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '3.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec-its
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: coveralls
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '0.7'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '0.7'
69
+ - !ruby/object:Gem::Dependency
70
+ name: activerecord
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '3'
76
+ - - "<"
77
+ - !ruby/object:Gem::Version
78
+ version: '5'
79
+ type: :development
80
+ prerelease: false
81
+ version_requirements: !ruby/object:Gem::Requirement
82
+ requirements:
83
+ - - ">="
84
+ - !ruby/object:Gem::Version
85
+ version: '3'
86
+ - - "<"
87
+ - !ruby/object:Gem::Version
88
+ version: '5'
89
+ - !ruby/object:Gem::Dependency
90
+ name: database_cleaner
91
+ requirement: !ruby/object:Gem::Requirement
92
+ requirements:
93
+ - - ">="
94
+ - !ruby/object:Gem::Version
95
+ version: '0'
96
+ type: :development
97
+ prerelease: false
98
+ version_requirements: !ruby/object:Gem::Requirement
99
+ requirements:
100
+ - - ">="
101
+ - !ruby/object:Gem::Version
102
+ version: '0'
103
+ - !ruby/object:Gem::Dependency
104
+ name: sqlite3
105
+ requirement: !ruby/object:Gem::Requirement
106
+ requirements:
107
+ - - ">="
108
+ - !ruby/object:Gem::Version
109
+ version: '0'
110
+ type: :development
111
+ prerelease: false
112
+ version_requirements: !ruby/object:Gem::Requirement
113
+ requirements:
114
+ - - ">="
115
+ - !ruby/object:Gem::Version
116
+ version: '0'
117
+ description:
118
+ email:
119
+ - daniel@claudetech.com
120
+ executables: []
121
+ extensions: []
122
+ extra_rdoc_files: []
123
+ files:
124
+ - ".gitignore"
125
+ - ".rspec"
126
+ - ".rubocop.yml"
127
+ - ".ruby-version"
128
+ - ".travis.yml"
129
+ - Gemfile
130
+ - Guardfile
131
+ - LICENSE
132
+ - README.md
133
+ - Rakefile
134
+ - lib/simple-api-auth.rb
135
+ - lib/simple-api-auth/authenticable.rb
136
+ - lib/simple-api-auth/authenticator.rb
137
+ - lib/simple-api-auth/config.rb
138
+ - lib/simple-api-auth/hashers/sha1_hasher.rb
139
+ - lib/simple-api-auth/helpers/auth_helpers.rb
140
+ - lib/simple-api-auth/helpers/request_helpers.rb
141
+ - lib/simple-api-auth/request.rb
142
+ - lib/simple-api-auth/signer.rb
143
+ - lib/simple-api-auth/version.rb
144
+ - simple-api-auth.gemspec
145
+ - spec/extensions/string_spec.rb
146
+ - spec/internal/app/models/models.rb
147
+ - spec/internal/config/database.yml
148
+ - spec/internal/db/schema.rb
149
+ - spec/lib/simple-api-auth/authenticable_spec.rb
150
+ - spec/lib/simple-api-auth/authenticator_spec.rb
151
+ - spec/lib/simple-api-auth/config_spec.rb
152
+ - spec/lib/simple-api-auth/helpers/auth_helpers_spec.rb
153
+ - spec/lib/simple-api-auth/helpers/request_helpers_spec.rb
154
+ - spec/lib/simple-api-auth/request_spec.rb
155
+ - spec/lib/simple-api-auth/signer_spec.rb
156
+ - spec/lib/simple-api-auth_spec.rb
157
+ - spec/spec_helper.rb
158
+ - spec/support/auth.rb
159
+ - spec/support/database.rb
160
+ - spec/support/database_cleaner.rb
161
+ - spec/support/extensions.rb
162
+ - spec/support/mocks.rb
163
+ - spec/support/requests.rb
164
+ homepage: https://github.com/claude-tech/ruby-simple-api-auth
165
+ licenses:
166
+ - MIT
167
+ metadata: {}
168
+ post_install_message:
169
+ rdoc_options: []
170
+ require_paths:
171
+ - lib
172
+ required_ruby_version: !ruby/object:Gem::Requirement
173
+ requirements:
174
+ - - ">="
175
+ - !ruby/object:Gem::Version
176
+ version: '0'
177
+ required_rubygems_version: !ruby/object:Gem::Requirement
178
+ requirements:
179
+ - - ">="
180
+ - !ruby/object:Gem::Version
181
+ version: '0'
182
+ requirements: []
183
+ rubyforge_project:
184
+ rubygems_version: 2.2.2
185
+ signing_key:
186
+ specification_version: 4
187
+ summary: Basic token based authentication for APIs
188
+ test_files: []
189
+ has_rdoc: