token_authenticate_me 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (48) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +4 -0
  3. data/.rubocop.yml +8 -0
  4. data/Gemfile +7 -0
  5. data/LICENSE +20 -0
  6. data/README.md +47 -0
  7. data/Rakefile +17 -0
  8. data/app/mailers/token_authenticate_me_mailer.rb +28 -0
  9. data/app/views/token_authenticate_me_mailer/invalid_user_reset_password_email.html.erb +20 -0
  10. data/app/views/token_authenticate_me_mailer/invalid_user_reset_password_email.text.erb +13 -0
  11. data/app/views/token_authenticate_me_mailer/valid_user_reset_password_email.html.erb +16 -0
  12. data/app/views/token_authenticate_me_mailer/valid_user_reset_password_email.text.erb +9 -0
  13. data/config.ru +7 -0
  14. data/lib/generators/token_authenticate_me/controllers/controllers_generator.rb +37 -0
  15. data/lib/generators/token_authenticate_me/controllers/templates/password_reset.rb +6 -0
  16. data/lib/generators/token_authenticate_me/controllers/templates/sessions.rb +6 -0
  17. data/lib/generators/token_authenticate_me/install/install_generator.rb +12 -0
  18. data/lib/generators/token_authenticate_me/models/models_generator.rb +55 -0
  19. data/lib/generators/token_authenticate_me/models/templates/authentication_migration.rb +20 -0
  20. data/lib/generators/token_authenticate_me/models/templates/authentication_model.rb +6 -0
  21. data/lib/generators/token_authenticate_me/models/templates/session_migration.rb +17 -0
  22. data/lib/generators/token_authenticate_me/models/templates/session_model.rb +6 -0
  23. data/lib/token_authenticate_me.rb +6 -0
  24. data/lib/token_authenticate_me/controllers/password_resetable.rb +90 -0
  25. data/lib/token_authenticate_me/controllers/sessionable.rb +63 -0
  26. data/lib/token_authenticate_me/controllers/token_authenticateable.rb +43 -0
  27. data/lib/token_authenticate_me/engine.rb +5 -0
  28. data/lib/token_authenticate_me/models/authenticatable.rb +40 -0
  29. data/lib/token_authenticate_me/models/sessionable.rb +27 -0
  30. data/lib/token_authenticate_me/version.rb +3 -0
  31. data/spec/acceptance/password_reset_api_spec.rb +111 -0
  32. data/spec/acceptance/session_api_spec.rb +95 -0
  33. data/spec/acceptance/users_api_spec.rb +56 -0
  34. data/spec/internal/app/controllers/application_controller.rb +5 -0
  35. data/spec/internal/app/controllers/password_resets_controller.rb +5 -0
  36. data/spec/internal/app/controllers/sessions_controller.rb +5 -0
  37. data/spec/internal/app/controllers/users_controller.rb +7 -0
  38. data/spec/internal/app/models/session.rb +5 -0
  39. data/spec/internal/app/models/user.rb +5 -0
  40. data/spec/internal/app/policies/user_policy.rb +25 -0
  41. data/spec/internal/app/serializers/user_serializer.rb +3 -0
  42. data/spec/internal/config/database.yml +3 -0
  43. data/spec/internal/config/routes.rb +13 -0
  44. data/spec/internal/db/fixtures/users.rb +11 -0
  45. data/spec/internal/db/schema.rb +19 -0
  46. data/spec/spec_helper.rb +38 -0
  47. data/token_authenticate_me.gemspec +32 -0
  48. metadata +245 -0
@@ -0,0 +1,5 @@
1
+ class ApplicationController < ActionController::Base
2
+ # Prevent CSRF attacks by raising an exception.
3
+ # For APIs, you may want to use :null_session instead.
4
+ protect_from_forgery with: :exception
5
+ end
@@ -0,0 +1,5 @@
1
+ require 'token_authenticate_me/controllers/password_resetable'
2
+
3
+ class PasswordResetsController < ApplicationController
4
+ include TokenAuthenticateMe::Controllers::PasswordResetable
5
+ end
@@ -0,0 +1,5 @@
1
+ require 'token_authenticate_me/controllers/sessionable'
2
+
3
+ class SessionsController < ApplicationController
4
+ include TokenAuthenticateMe::Controllers::Sessionable
5
+ end
@@ -0,0 +1,7 @@
1
+ class UsersController < ApplicationController
2
+ include TokenAuthenticateMe::Controllers::TokenAuthenticateable
3
+ include ApiMe # Provides default api resource
4
+
5
+ # Allow anyone to create a new user
6
+ skip_before_action :authenticate, only: [:create]
7
+ end
@@ -0,0 +1,5 @@
1
+ require 'token_authenticate_me/models/sessionable'
2
+
3
+ class Session < ActiveRecord::Base
4
+ include TokenAuthenticateMe::Models::Sessionable
5
+ end
@@ -0,0 +1,5 @@
1
+ require 'token_authenticate_me/models/authenticatable'
2
+
3
+ class User < ActiveRecord::Base
4
+ include TokenAuthenticateMe::Models::Authenticatable
5
+ end
@@ -0,0 +1,25 @@
1
+ class UserPolicy
2
+ def initialize(*)
3
+ end
4
+
5
+ def permitted_attributes
6
+ [:username, :email, :password, :password_confirmation]
7
+ end
8
+
9
+ def create?
10
+ true
11
+ end
12
+
13
+ class Scope
14
+ attr_reader :user, :scope
15
+
16
+ def initialize(user, scope)
17
+ @user = user
18
+ @scope = scope
19
+ end
20
+
21
+ def resolve
22
+ scope
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,3 @@
1
+ class UserSerializer < ActiveModel::Serializer
2
+ attributes :id, :username, :email, :password, :created_at, :updated_at
3
+ end
@@ -0,0 +1,3 @@
1
+ test:
2
+ adapter: sqlite3
3
+ database: db/combustion_test.sqlite
@@ -0,0 +1,13 @@
1
+ Rails.application.routes.draw do
2
+ resource :session, only: [:create, :show, :destroy]
3
+
4
+ resources :users
5
+
6
+ resources(
7
+ :password_resets,
8
+ only: [:create, :update],
9
+ constraints: {
10
+ id: TokenAuthenticateMe::UUID_REGEX
11
+ }
12
+ )
13
+ end
@@ -0,0 +1,11 @@
1
+ module Fixtures
2
+ module Users
3
+ def create_user(username: 'test', email: 'test@email.com', password: 'password')
4
+ User.create!(
5
+ username: username,
6
+ email: email,
7
+ password: password
8
+ )
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,19 @@
1
+ ActiveRecord::Schema.define do
2
+ create_table :users, force: true do |t|
3
+ t.string :username, null: false
4
+ t.string :email, null: false
5
+ t.string :password_digest, null: false
6
+ t.string :reset_password_token
7
+ t.datetime :reset_password_token_exp
8
+
9
+ t.timestamps
10
+ end
11
+
12
+ create_table :sessions, force: true do |t|
13
+ t.string :key, null: false
14
+ t.datetime :expiration
15
+ t.integer :user_id
16
+
17
+ t.timestamps
18
+ end
19
+ end
@@ -0,0 +1,38 @@
1
+ require 'rubygems'
2
+ require 'bundler/setup'
3
+ require 'combustion'
4
+
5
+ Bundler.require :default, :development
6
+
7
+ Combustion.initialize! :active_record, :action_controller, :action_mailer, :action_view
8
+
9
+ require 'rspec/rails'
10
+ require 'rack/test'
11
+
12
+ # Load fixture helpers for testing
13
+ Dir[File.join(File.dirname(__FILE__), 'internal', 'db', 'fixtures', '**', '*.rb')].each do |file|
14
+ require file
15
+ end
16
+
17
+ module ApiHelper
18
+ include Rack::Test::Methods
19
+
20
+ def app
21
+ Rails.application
22
+ end
23
+ end
24
+
25
+ RSpec.configure do |config|
26
+ config.use_transactional_fixtures = true
27
+ config.mock_with :rspec
28
+
29
+ config.before do
30
+ ActionMailer::Base.delivery_method = :test
31
+ ActionMailer::Base.default_options = {
32
+ from: 'no-reply@test.com'
33
+ }
34
+ end
35
+
36
+ config.include ApiHelper
37
+ config.include Fixtures::Users
38
+ end
@@ -0,0 +1,32 @@
1
+ # -*- encoding: utf-8 -*-
2
+
3
+ lib = File.expand_path('../lib', __FILE__)
4
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
5
+ require 'token_authenticate_me/version'
6
+
7
+ Gem::Specification.new do |s|
8
+ s.name = 'token_authenticate_me'
9
+ s.version = TokenAuthenticateMe::VERSION
10
+ s.authors = ['Sam Clopton', 'Joe Weakley']
11
+ s.email = ['samsinite@gmail.com']
12
+ s.homepage = 'https://github.com/inigo-llc/token_authenticate_me'
13
+ s.summary = 'This gem adds simple token authentication to users.'
14
+ s.license = 'MIT'
15
+
16
+ s.files = `git ls-files`.split("\n")
17
+ s.test_files = `git ls-files -- {spec}/*`.split("\n")
18
+ s.require_paths = ['lib']
19
+
20
+ s.add_runtime_dependency 'activerecord', '>= 3.2.0'
21
+ s.add_runtime_dependency 'activesupport', '>= 3.2.0'
22
+ s.add_runtime_dependency 'actionmailer', '>= 3.2.0'
23
+ s.add_runtime_dependency 'actionpack'
24
+ s.add_runtime_dependency 'bcrypt', '~> 3.1.9'
25
+
26
+ s.add_development_dependency 'rubocop', '>= 0.27.0'
27
+ s.add_development_dependency 'combustion', '~> 0.5.2'
28
+ s.add_development_dependency 'rack-test'
29
+ s.add_development_dependency 'rspec-rails'
30
+ s.add_development_dependency 'sqlite3'
31
+ s.add_development_dependency 'api_me'
32
+ end
metadata ADDED
@@ -0,0 +1,245 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: token_authenticate_me
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.2.0
5
+ platform: ruby
6
+ authors:
7
+ - Sam Clopton
8
+ - Joe Weakley
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2014-11-17 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: activerecord
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - ">="
19
+ - !ruby/object:Gem::Version
20
+ version: 3.2.0
21
+ type: :runtime
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - ">="
26
+ - !ruby/object:Gem::Version
27
+ version: 3.2.0
28
+ - !ruby/object:Gem::Dependency
29
+ name: activesupport
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - ">="
33
+ - !ruby/object:Gem::Version
34
+ version: 3.2.0
35
+ type: :runtime
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ">="
40
+ - !ruby/object:Gem::Version
41
+ version: 3.2.0
42
+ - !ruby/object:Gem::Dependency
43
+ name: actionmailer
44
+ requirement: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - ">="
47
+ - !ruby/object:Gem::Version
48
+ version: 3.2.0
49
+ type: :runtime
50
+ prerelease: false
51
+ version_requirements: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - ">="
54
+ - !ruby/object:Gem::Version
55
+ version: 3.2.0
56
+ - !ruby/object:Gem::Dependency
57
+ name: actionpack
58
+ requirement: !ruby/object:Gem::Requirement
59
+ requirements:
60
+ - - ">="
61
+ - !ruby/object:Gem::Version
62
+ version: '0'
63
+ type: :runtime
64
+ prerelease: false
65
+ version_requirements: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - ">="
68
+ - !ruby/object:Gem::Version
69
+ version: '0'
70
+ - !ruby/object:Gem::Dependency
71
+ name: bcrypt
72
+ requirement: !ruby/object:Gem::Requirement
73
+ requirements:
74
+ - - "~>"
75
+ - !ruby/object:Gem::Version
76
+ version: 3.1.9
77
+ type: :runtime
78
+ prerelease: false
79
+ version_requirements: !ruby/object:Gem::Requirement
80
+ requirements:
81
+ - - "~>"
82
+ - !ruby/object:Gem::Version
83
+ version: 3.1.9
84
+ - !ruby/object:Gem::Dependency
85
+ name: rubocop
86
+ requirement: !ruby/object:Gem::Requirement
87
+ requirements:
88
+ - - ">="
89
+ - !ruby/object:Gem::Version
90
+ version: 0.27.0
91
+ type: :development
92
+ prerelease: false
93
+ version_requirements: !ruby/object:Gem::Requirement
94
+ requirements:
95
+ - - ">="
96
+ - !ruby/object:Gem::Version
97
+ version: 0.27.0
98
+ - !ruby/object:Gem::Dependency
99
+ name: combustion
100
+ requirement: !ruby/object:Gem::Requirement
101
+ requirements:
102
+ - - "~>"
103
+ - !ruby/object:Gem::Version
104
+ version: 0.5.2
105
+ type: :development
106
+ prerelease: false
107
+ version_requirements: !ruby/object:Gem::Requirement
108
+ requirements:
109
+ - - "~>"
110
+ - !ruby/object:Gem::Version
111
+ version: 0.5.2
112
+ - !ruby/object:Gem::Dependency
113
+ name: rack-test
114
+ requirement: !ruby/object:Gem::Requirement
115
+ requirements:
116
+ - - ">="
117
+ - !ruby/object:Gem::Version
118
+ version: '0'
119
+ type: :development
120
+ prerelease: false
121
+ version_requirements: !ruby/object:Gem::Requirement
122
+ requirements:
123
+ - - ">="
124
+ - !ruby/object:Gem::Version
125
+ version: '0'
126
+ - !ruby/object:Gem::Dependency
127
+ name: rspec-rails
128
+ requirement: !ruby/object:Gem::Requirement
129
+ requirements:
130
+ - - ">="
131
+ - !ruby/object:Gem::Version
132
+ version: '0'
133
+ type: :development
134
+ prerelease: false
135
+ version_requirements: !ruby/object:Gem::Requirement
136
+ requirements:
137
+ - - ">="
138
+ - !ruby/object:Gem::Version
139
+ version: '0'
140
+ - !ruby/object:Gem::Dependency
141
+ name: sqlite3
142
+ requirement: !ruby/object:Gem::Requirement
143
+ requirements:
144
+ - - ">="
145
+ - !ruby/object:Gem::Version
146
+ version: '0'
147
+ type: :development
148
+ prerelease: false
149
+ version_requirements: !ruby/object:Gem::Requirement
150
+ requirements:
151
+ - - ">="
152
+ - !ruby/object:Gem::Version
153
+ version: '0'
154
+ - !ruby/object:Gem::Dependency
155
+ name: api_me
156
+ requirement: !ruby/object:Gem::Requirement
157
+ requirements:
158
+ - - ">="
159
+ - !ruby/object:Gem::Version
160
+ version: '0'
161
+ type: :development
162
+ prerelease: false
163
+ version_requirements: !ruby/object:Gem::Requirement
164
+ requirements:
165
+ - - ">="
166
+ - !ruby/object:Gem::Version
167
+ version: '0'
168
+ description:
169
+ email:
170
+ - samsinite@gmail.com
171
+ executables: []
172
+ extensions: []
173
+ extra_rdoc_files: []
174
+ files:
175
+ - ".gitignore"
176
+ - ".rubocop.yml"
177
+ - Gemfile
178
+ - LICENSE
179
+ - README.md
180
+ - Rakefile
181
+ - app/mailers/token_authenticate_me_mailer.rb
182
+ - app/views/token_authenticate_me_mailer/invalid_user_reset_password_email.html.erb
183
+ - app/views/token_authenticate_me_mailer/invalid_user_reset_password_email.text.erb
184
+ - app/views/token_authenticate_me_mailer/valid_user_reset_password_email.html.erb
185
+ - app/views/token_authenticate_me_mailer/valid_user_reset_password_email.text.erb
186
+ - config.ru
187
+ - lib/generators/token_authenticate_me/controllers/controllers_generator.rb
188
+ - lib/generators/token_authenticate_me/controllers/templates/password_reset.rb
189
+ - lib/generators/token_authenticate_me/controllers/templates/sessions.rb
190
+ - lib/generators/token_authenticate_me/install/install_generator.rb
191
+ - lib/generators/token_authenticate_me/models/models_generator.rb
192
+ - lib/generators/token_authenticate_me/models/templates/authentication_migration.rb
193
+ - lib/generators/token_authenticate_me/models/templates/authentication_model.rb
194
+ - lib/generators/token_authenticate_me/models/templates/session_migration.rb
195
+ - lib/generators/token_authenticate_me/models/templates/session_model.rb
196
+ - lib/token_authenticate_me.rb
197
+ - lib/token_authenticate_me/controllers/password_resetable.rb
198
+ - lib/token_authenticate_me/controllers/sessionable.rb
199
+ - lib/token_authenticate_me/controllers/token_authenticateable.rb
200
+ - lib/token_authenticate_me/engine.rb
201
+ - lib/token_authenticate_me/models/authenticatable.rb
202
+ - lib/token_authenticate_me/models/sessionable.rb
203
+ - lib/token_authenticate_me/version.rb
204
+ - spec/acceptance/password_reset_api_spec.rb
205
+ - spec/acceptance/session_api_spec.rb
206
+ - spec/acceptance/users_api_spec.rb
207
+ - spec/internal/app/controllers/application_controller.rb
208
+ - spec/internal/app/controllers/password_resets_controller.rb
209
+ - spec/internal/app/controllers/sessions_controller.rb
210
+ - spec/internal/app/controllers/users_controller.rb
211
+ - spec/internal/app/models/session.rb
212
+ - spec/internal/app/models/user.rb
213
+ - spec/internal/app/policies/user_policy.rb
214
+ - spec/internal/app/serializers/user_serializer.rb
215
+ - spec/internal/config/database.yml
216
+ - spec/internal/config/routes.rb
217
+ - spec/internal/db/fixtures/users.rb
218
+ - spec/internal/db/schema.rb
219
+ - spec/spec_helper.rb
220
+ - token_authenticate_me.gemspec
221
+ homepage: https://github.com/inigo-llc/token_authenticate_me
222
+ licenses:
223
+ - MIT
224
+ metadata: {}
225
+ post_install_message:
226
+ rdoc_options: []
227
+ require_paths:
228
+ - lib
229
+ required_ruby_version: !ruby/object:Gem::Requirement
230
+ requirements:
231
+ - - ">="
232
+ - !ruby/object:Gem::Version
233
+ version: '0'
234
+ required_rubygems_version: !ruby/object:Gem::Requirement
235
+ requirements:
236
+ - - ">="
237
+ - !ruby/object:Gem::Version
238
+ version: '0'
239
+ requirements: []
240
+ rubyforge_project:
241
+ rubygems_version: 2.2.2
242
+ signing_key:
243
+ specification_version: 4
244
+ summary: This gem adds simple token authentication to users.
245
+ test_files: []