simple-api-auth 0.1.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.
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: