token_authenticate_me 0.2.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 (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: []