devise_fido_usf 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,28 @@
1
+ require 'rails/generators/active_record'
2
+
3
+ module DeviseFidoUsf
4
+ module Generators
5
+ class MigrateGenerator < ActiveRecord::Generators::Base
6
+ argument :attributes, type: :array, default: [], banner: "field:type field:type"
7
+
8
+ source_root File.expand_path("../../templates", __FILE__)
9
+
10
+ desc "Creates the migration for the table which stores all registered FIDO USF devices."
11
+
12
+ def copy_fido_usf_device_migration
13
+ migration_template "migration.rb", "db/migrate/create_#{table_name}.rb", migration_version: migration_version
14
+ end
15
+
16
+ def rails5?
17
+ Rails.version.start_with? '5'
18
+ end
19
+
20
+ def migration_version
21
+ if rails5?
22
+ "[#{Rails::VERSION::MAJOR}.#{Rails::VERSION::MINOR}]"
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
28
+
@@ -0,0 +1,44 @@
1
+ ===============================================================================
2
+
3
+ Device FIDO U2F successfully installed to your application.
4
+
5
+ You need to:
6
+
7
+ 1) Adapt your Devise models to include both the FIDO U2F registration and
8
+ authentication modules, e.g. change
9
+
10
+ 'devise :database_authenticable ...'
11
+
12
+ to
13
+
14
+ 'devise :database_authenticable ...,
15
+ :fido_usf_registerable, :fido_usf_authenticatable'
16
+
17
+ 2) Modify your application controller
18
+ (i.e. app/controllers/application_controller.rb) to always prepend the
19
+ 'protect_from_forgery' within the action chain, e.g. change
20
+
21
+ 'protect_from_forgery with: :exception'
22
+
23
+ to
24
+
25
+ 'protect_from_forgery with: :exception, prepend: true'
26
+
27
+ 3) Add 'u2f-api.js' to your javascript assets, e.g. include in
28
+ 'app/assets/javascript/application.js' the following statement:
29
+
30
+ '//= require u2f-api'
31
+
32
+ 4) You need to run your server with SSL. Otherwise U2F refuses to work.
33
+ Probably you want to install the "thin" gem and use:
34
+
35
+ 'thin start --ssl -p 3000'
36
+
37
+ to start your development server.
38
+
39
+
40
+ DISCLAIMER: IF YOU DO NOT APPLY BOTH CHANGES, IT IS LIKELY THAT
41
+ FIDO U2F WILL NOT WORK AS EXPECTED!
42
+
43
+ ===============================================================================
44
+
@@ -0,0 +1,19 @@
1
+ class Create<%= table_name.camelize %> < ActiveRecord::Migration<%= migration_version %>
2
+ def change
3
+ create_table :<%= table_name %> do |t|
4
+ t.references :user, null: false, polymorphic: true, index: true
5
+ t.string :name, null: false, default: ""
6
+ t.string :key_handle, null: false, limit: 255, default: ""
7
+ t.binary :public_key, null: false, limit: 10.kilobytes, default: ""
8
+ t.binary :certificate, null: false, limit: 1.megabyte, default: ""
9
+ t.integer :counter, null: false, default: 0
10
+ t.timestamp :last_authenticated_at, null: false
11
+ <% attributes.each do |attribute| -%>
12
+ t.<%= attribute.type %> :<%= attribute.name %>
13
+ <% end -%>
14
+ t.timestamps
15
+ end
16
+ add_index :<%= table_name %>, :key_handle
17
+ add_index :<%= table_name %>, :last_authenticated_at
18
+ end
19
+ end
@@ -0,0 +1,4 @@
1
+ # desc "Explaining what the task does"
2
+ # task :devise_fido_usf do
3
+ # # Task goes here
4
+ # end
metadata ADDED
@@ -0,0 +1,240 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: devise_fido_usf
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - H. Gregor Molter
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2017-09-08 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rails
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '5.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '5.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: devise
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '4.2'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '4.2'
41
+ - !ruby/object:Gem::Dependency
42
+ name: u2f
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - '='
46
+ - !ruby/object:Gem::Version
47
+ version: 1.0.0
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '='
53
+ - !ruby/object:Gem::Version
54
+ version: 1.0.0
55
+ - !ruby/object:Gem::Dependency
56
+ name: sqlite3
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: thin
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: capybara
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: launchy
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: simplecov
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: '0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: coveralls
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: rkelly-remix
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: rails-controller-testing
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - ">="
158
+ - !ruby/object:Gem::Version
159
+ version: '0'
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - ">="
165
+ - !ruby/object:Gem::Version
166
+ version: '0'
167
+ - !ruby/object:Gem::Dependency
168
+ name: pry
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - ">="
172
+ - !ruby/object:Gem::Version
173
+ version: '0'
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - ">="
179
+ - !ruby/object:Gem::Version
180
+ version: '0'
181
+ description: Enables a Rails Devise app to authenticate users with a second factor,
182
+ e.g. a FIDO U2F compatible hardware token.
183
+ email:
184
+ - gregor.molter@secretlab.de
185
+ executables: []
186
+ extensions: []
187
+ extra_rdoc_files: []
188
+ files:
189
+ - MIT-LICENSE
190
+ - README.md
191
+ - Rakefile
192
+ - app/assets/javascript/u2f-api.js
193
+ - app/controllers/devise/fido_usf_authentications_controller.rb
194
+ - app/controllers/devise/fido_usf_registrations_controller.rb
195
+ - app/models/fido_usf/fido_usf_device.rb
196
+ - app/views/devise/fido_usf_authentications/new.html.erb
197
+ - app/views/devise/fido_usf_registrations/_device.html.erb
198
+ - app/views/devise/fido_usf_registrations/_devices.html.erb
199
+ - app/views/devise/fido_usf_registrations/destroy.js.erb
200
+ - app/views/devise/fido_usf_registrations/new.html.erb
201
+ - app/views/devise/fido_usf_registrations/show.html.erb
202
+ - config/locales/en.yml
203
+ - lib/devise_fido_usf.rb
204
+ - lib/devise_fido_usf/controllers/helpers.rb
205
+ - lib/devise_fido_usf/hooks/fido_usf_authenticatable.rb
206
+ - lib/devise_fido_usf/models/fido_usf_authenticatable.rb
207
+ - lib/devise_fido_usf/models/fido_usf_registerable.rb
208
+ - lib/devise_fido_usf/rails.rb
209
+ - lib/devise_fido_usf/routes.rb
210
+ - lib/devise_fido_usf/version.rb
211
+ - lib/generators/devise_fido_usf/install_generator.rb
212
+ - lib/generators/devise_fido_usf/migrate_generator.rb
213
+ - lib/generators/templates/README
214
+ - lib/generators/templates/migration.rb
215
+ - lib/tasks/devise_fido_usf_tasks.rake
216
+ homepage: https://github.com/CyberDeck/devise-fido-u2f/
217
+ licenses:
218
+ - MIT
219
+ metadata: {}
220
+ post_install_message:
221
+ rdoc_options: []
222
+ require_paths:
223
+ - lib
224
+ required_ruby_version: !ruby/object:Gem::Requirement
225
+ requirements:
226
+ - - ">="
227
+ - !ruby/object:Gem::Version
228
+ version: '0'
229
+ required_rubygems_version: !ruby/object:Gem::Requirement
230
+ requirements:
231
+ - - ">="
232
+ - !ruby/object:Gem::Version
233
+ version: '0'
234
+ requirements: []
235
+ rubyforge_project:
236
+ rubygems_version: 2.5.2
237
+ signing_key:
238
+ specification_version: 4
239
+ summary: A Devise module to allow FIDO U2F authentication.
240
+ test_files: []