openid-token-proxy 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (92) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +5 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +6 -0
  5. data/CHANGELOG.md +5 -0
  6. data/Gemfile +4 -0
  7. data/Guardfile +41 -0
  8. data/LICENSE.md +22 -0
  9. data/README.md +211 -0
  10. data/Rakefile +16 -0
  11. data/app/controllers/openid_token_proxy/application_controller.rb +4 -0
  12. data/app/controllers/openid_token_proxy/callback_controller.rb +22 -0
  13. data/config/initializers/inflections.rb +3 -0
  14. data/config/routes.rb +3 -0
  15. data/docs/diagrams.sketch +0 -0
  16. data/docs/openid-token-proxy-flow.png +0 -0
  17. data/docs/regular-openid-flow.png +0 -0
  18. data/lib/openid-token-proxy.rb +1 -0
  19. data/lib/openid_token_proxy/client.rb +48 -0
  20. data/lib/openid_token_proxy/config.rb +56 -0
  21. data/lib/openid_token_proxy/engine.rb +5 -0
  22. data/lib/openid_token_proxy/error.rb +7 -0
  23. data/lib/openid_token_proxy/token/authentication.rb +54 -0
  24. data/lib/openid_token_proxy/token/expired.rb +12 -0
  25. data/lib/openid_token_proxy/token/invalid_application.rb +12 -0
  26. data/lib/openid_token_proxy/token/invalid_audience.rb +12 -0
  27. data/lib/openid_token_proxy/token/invalid_issuer.rb +12 -0
  28. data/lib/openid_token_proxy/token/malformed.rb +12 -0
  29. data/lib/openid_token_proxy/token/refresh.rb +30 -0
  30. data/lib/openid_token_proxy/token/required.rb +12 -0
  31. data/lib/openid_token_proxy/token/unverifiable_signature.rb +12 -0
  32. data/lib/openid_token_proxy/token.rb +80 -0
  33. data/lib/openid_token_proxy/version.rb +3 -0
  34. data/lib/openid_token_proxy.rb +40 -0
  35. data/openid-token-proxy.gemspec +35 -0
  36. data/spec/controllers/openid_token_proxy/callback_controller_spec.rb +72 -0
  37. data/spec/dummy/README.rdoc +28 -0
  38. data/spec/dummy/Rakefile +6 -0
  39. data/spec/dummy/app/assets/images/.keep +0 -0
  40. data/spec/dummy/app/assets/javascripts/application.js +13 -0
  41. data/spec/dummy/app/assets/stylesheets/application.css +15 -0
  42. data/spec/dummy/app/controllers/accounts_controller.rb +10 -0
  43. data/spec/dummy/app/controllers/application_controller.rb +5 -0
  44. data/spec/dummy/app/controllers/concerns/.keep +0 -0
  45. data/spec/dummy/app/controllers/home_controller.rb +7 -0
  46. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  47. data/spec/dummy/app/mailers/.keep +0 -0
  48. data/spec/dummy/app/models/.keep +0 -0
  49. data/spec/dummy/app/models/concerns/.keep +0 -0
  50. data/spec/dummy/app/views/home/index.html.erb +25 -0
  51. data/spec/dummy/app/views/layouts/application.html.erb +54 -0
  52. data/spec/dummy/bin/bundle +3 -0
  53. data/spec/dummy/bin/rails +4 -0
  54. data/spec/dummy/bin/rake +4 -0
  55. data/spec/dummy/config/application.rb +27 -0
  56. data/spec/dummy/config/boot.rb +5 -0
  57. data/spec/dummy/config/environment.rb +5 -0
  58. data/spec/dummy/config/environments/development.rb +34 -0
  59. data/spec/dummy/config/environments/production.rb +75 -0
  60. data/spec/dummy/config/environments/test.rb +39 -0
  61. data/spec/dummy/config/initializers/assets.rb +8 -0
  62. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  63. data/spec/dummy/config/initializers/cookies_serializer.rb +3 -0
  64. data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  65. data/spec/dummy/config/initializers/inflections.rb +16 -0
  66. data/spec/dummy/config/initializers/mime_types.rb +4 -0
  67. data/spec/dummy/config/initializers/openid.rb +5 -0
  68. data/spec/dummy/config/initializers/session_store.rb +3 -0
  69. data/spec/dummy/config/initializers/wrap_parameters.rb +9 -0
  70. data/spec/dummy/config/locales/en.yml +23 -0
  71. data/spec/dummy/config/routes.rb +5 -0
  72. data/spec/dummy/config/secrets.yml +22 -0
  73. data/spec/dummy/config.ru +4 -0
  74. data/spec/dummy/lib/assets/.keep +0 -0
  75. data/spec/dummy/log/.keep +0 -0
  76. data/spec/dummy/public/404.html +67 -0
  77. data/spec/dummy/public/422.html +67 -0
  78. data/spec/dummy/public/500.html +66 -0
  79. data/spec/dummy/public/favicon.ico +0 -0
  80. data/spec/fixtures/keys.json +26 -0
  81. data/spec/fixtures/openid-configuration.json +30 -0
  82. data/spec/lib/openid_token_proxy/client_spec.rb +150 -0
  83. data/spec/lib/openid_token_proxy/config_spec.rb +201 -0
  84. data/spec/lib/openid_token_proxy/error_spec.rb +11 -0
  85. data/spec/lib/openid_token_proxy/token/authentication_spec.rb +67 -0
  86. data/spec/lib/openid_token_proxy/token/refresh_spec.rb +71 -0
  87. data/spec/lib/openid_token_proxy/token_spec.rb +138 -0
  88. data/spec/lib/openid_token_proxy_spec.rb +38 -0
  89. data/spec/spec_helper.rb +88 -0
  90. data/spec/support/env.rb +4 -0
  91. data/spec/support/fixture.rb +3 -0
  92. metadata +359 -0
metadata ADDED
@@ -0,0 +1,359 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: openid-token-proxy
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Tim Kurvers
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-05-06 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: openid_connect
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: 0.8.3
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: 0.8.3
27
+ - !ruby/object:Gem::Dependency
28
+ name: rails
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '4.0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '4.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.6'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.6'
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.12
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.12
69
+ - !ruby/object:Gem::Dependency
70
+ name: guard
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: 2.12.5
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: 2.12.5
83
+ - !ruby/object:Gem::Dependency
84
+ name: guard-rspec
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: 4.5.0
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: 4.5.0
97
+ - !ruby/object:Gem::Dependency
98
+ name: pry
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: 0.10.1
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: 0.10.1
111
+ - !ruby/object:Gem::Dependency
112
+ name: pry-rails
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: 0.3.4
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: 0.3.4
125
+ - !ruby/object:Gem::Dependency
126
+ name: rake
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: '10.0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - "~>"
137
+ - !ruby/object:Gem::Version
138
+ version: '10.0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: rspec-rails
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - "~>"
144
+ - !ruby/object:Gem::Version
145
+ version: 3.2.1
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - "~>"
151
+ - !ruby/object:Gem::Version
152
+ version: 3.2.1
153
+ - !ruby/object:Gem::Dependency
154
+ name: simplecov
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - "~>"
158
+ - !ruby/object:Gem::Version
159
+ version: 0.9.2
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - "~>"
165
+ - !ruby/object:Gem::Version
166
+ version: 0.9.2
167
+ - !ruby/object:Gem::Dependency
168
+ name: webmock
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - "~>"
172
+ - !ruby/object:Gem::Version
173
+ version: 1.21.0
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - "~>"
179
+ - !ruby/object:Gem::Version
180
+ version: 1.21.0
181
+ description: Retrieves and refreshes OpenID tokens on behalf of a user when dealing
182
+ with complex authentication schemes, such as client-side certificates
183
+ email:
184
+ - ruby@hyper.no
185
+ executables: []
186
+ extensions: []
187
+ extra_rdoc_files: []
188
+ files:
189
+ - ".gitignore"
190
+ - ".rspec"
191
+ - ".travis.yml"
192
+ - CHANGELOG.md
193
+ - Gemfile
194
+ - Guardfile
195
+ - LICENSE.md
196
+ - README.md
197
+ - Rakefile
198
+ - app/controllers/openid_token_proxy/application_controller.rb
199
+ - app/controllers/openid_token_proxy/callback_controller.rb
200
+ - config/initializers/inflections.rb
201
+ - config/routes.rb
202
+ - docs/diagrams.sketch
203
+ - docs/openid-token-proxy-flow.png
204
+ - docs/regular-openid-flow.png
205
+ - lib/openid-token-proxy.rb
206
+ - lib/openid_token_proxy.rb
207
+ - lib/openid_token_proxy/client.rb
208
+ - lib/openid_token_proxy/config.rb
209
+ - lib/openid_token_proxy/engine.rb
210
+ - lib/openid_token_proxy/error.rb
211
+ - lib/openid_token_proxy/token.rb
212
+ - lib/openid_token_proxy/token/authentication.rb
213
+ - lib/openid_token_proxy/token/expired.rb
214
+ - lib/openid_token_proxy/token/invalid_application.rb
215
+ - lib/openid_token_proxy/token/invalid_audience.rb
216
+ - lib/openid_token_proxy/token/invalid_issuer.rb
217
+ - lib/openid_token_proxy/token/malformed.rb
218
+ - lib/openid_token_proxy/token/refresh.rb
219
+ - lib/openid_token_proxy/token/required.rb
220
+ - lib/openid_token_proxy/token/unverifiable_signature.rb
221
+ - lib/openid_token_proxy/version.rb
222
+ - openid-token-proxy.gemspec
223
+ - spec/controllers/openid_token_proxy/callback_controller_spec.rb
224
+ - spec/dummy/README.rdoc
225
+ - spec/dummy/Rakefile
226
+ - spec/dummy/app/assets/images/.keep
227
+ - spec/dummy/app/assets/javascripts/application.js
228
+ - spec/dummy/app/assets/stylesheets/application.css
229
+ - spec/dummy/app/controllers/accounts_controller.rb
230
+ - spec/dummy/app/controllers/application_controller.rb
231
+ - spec/dummy/app/controllers/concerns/.keep
232
+ - spec/dummy/app/controllers/home_controller.rb
233
+ - spec/dummy/app/helpers/application_helper.rb
234
+ - spec/dummy/app/mailers/.keep
235
+ - spec/dummy/app/models/.keep
236
+ - spec/dummy/app/models/concerns/.keep
237
+ - spec/dummy/app/views/home/index.html.erb
238
+ - spec/dummy/app/views/layouts/application.html.erb
239
+ - spec/dummy/bin/bundle
240
+ - spec/dummy/bin/rails
241
+ - spec/dummy/bin/rake
242
+ - spec/dummy/config.ru
243
+ - spec/dummy/config/application.rb
244
+ - spec/dummy/config/boot.rb
245
+ - spec/dummy/config/environment.rb
246
+ - spec/dummy/config/environments/development.rb
247
+ - spec/dummy/config/environments/production.rb
248
+ - spec/dummy/config/environments/test.rb
249
+ - spec/dummy/config/initializers/assets.rb
250
+ - spec/dummy/config/initializers/backtrace_silencers.rb
251
+ - spec/dummy/config/initializers/cookies_serializer.rb
252
+ - spec/dummy/config/initializers/filter_parameter_logging.rb
253
+ - spec/dummy/config/initializers/inflections.rb
254
+ - spec/dummy/config/initializers/mime_types.rb
255
+ - spec/dummy/config/initializers/openid.rb
256
+ - spec/dummy/config/initializers/session_store.rb
257
+ - spec/dummy/config/initializers/wrap_parameters.rb
258
+ - spec/dummy/config/locales/en.yml
259
+ - spec/dummy/config/routes.rb
260
+ - spec/dummy/config/secrets.yml
261
+ - spec/dummy/lib/assets/.keep
262
+ - spec/dummy/log/.keep
263
+ - spec/dummy/public/404.html
264
+ - spec/dummy/public/422.html
265
+ - spec/dummy/public/500.html
266
+ - spec/dummy/public/favicon.ico
267
+ - spec/fixtures/keys.json
268
+ - spec/fixtures/openid-configuration.json
269
+ - spec/lib/openid_token_proxy/client_spec.rb
270
+ - spec/lib/openid_token_proxy/config_spec.rb
271
+ - spec/lib/openid_token_proxy/error_spec.rb
272
+ - spec/lib/openid_token_proxy/token/authentication_spec.rb
273
+ - spec/lib/openid_token_proxy/token/refresh_spec.rb
274
+ - spec/lib/openid_token_proxy/token_spec.rb
275
+ - spec/lib/openid_token_proxy_spec.rb
276
+ - spec/spec_helper.rb
277
+ - spec/support/env.rb
278
+ - spec/support/fixture.rb
279
+ homepage:
280
+ licenses:
281
+ - MIT
282
+ metadata: {}
283
+ post_install_message:
284
+ rdoc_options: []
285
+ require_paths:
286
+ - lib
287
+ required_ruby_version: !ruby/object:Gem::Requirement
288
+ requirements:
289
+ - - ">="
290
+ - !ruby/object:Gem::Version
291
+ version: '0'
292
+ required_rubygems_version: !ruby/object:Gem::Requirement
293
+ requirements:
294
+ - - ">="
295
+ - !ruby/object:Gem::Version
296
+ version: '0'
297
+ requirements: []
298
+ rubyforge_project:
299
+ rubygems_version: 2.2.2
300
+ signing_key:
301
+ specification_version: 4
302
+ summary: Retrieves and refreshes OpenID tokens on behalf of a user
303
+ test_files:
304
+ - spec/controllers/openid_token_proxy/callback_controller_spec.rb
305
+ - spec/dummy/README.rdoc
306
+ - spec/dummy/Rakefile
307
+ - spec/dummy/app/assets/images/.keep
308
+ - spec/dummy/app/assets/javascripts/application.js
309
+ - spec/dummy/app/assets/stylesheets/application.css
310
+ - spec/dummy/app/controllers/accounts_controller.rb
311
+ - spec/dummy/app/controllers/application_controller.rb
312
+ - spec/dummy/app/controllers/concerns/.keep
313
+ - spec/dummy/app/controllers/home_controller.rb
314
+ - spec/dummy/app/helpers/application_helper.rb
315
+ - spec/dummy/app/mailers/.keep
316
+ - spec/dummy/app/models/.keep
317
+ - spec/dummy/app/models/concerns/.keep
318
+ - spec/dummy/app/views/home/index.html.erb
319
+ - spec/dummy/app/views/layouts/application.html.erb
320
+ - spec/dummy/bin/bundle
321
+ - spec/dummy/bin/rails
322
+ - spec/dummy/bin/rake
323
+ - spec/dummy/config.ru
324
+ - spec/dummy/config/application.rb
325
+ - spec/dummy/config/boot.rb
326
+ - spec/dummy/config/environment.rb
327
+ - spec/dummy/config/environments/development.rb
328
+ - spec/dummy/config/environments/production.rb
329
+ - spec/dummy/config/environments/test.rb
330
+ - spec/dummy/config/initializers/assets.rb
331
+ - spec/dummy/config/initializers/backtrace_silencers.rb
332
+ - spec/dummy/config/initializers/cookies_serializer.rb
333
+ - spec/dummy/config/initializers/filter_parameter_logging.rb
334
+ - spec/dummy/config/initializers/inflections.rb
335
+ - spec/dummy/config/initializers/mime_types.rb
336
+ - spec/dummy/config/initializers/openid.rb
337
+ - spec/dummy/config/initializers/session_store.rb
338
+ - spec/dummy/config/initializers/wrap_parameters.rb
339
+ - spec/dummy/config/locales/en.yml
340
+ - spec/dummy/config/routes.rb
341
+ - spec/dummy/config/secrets.yml
342
+ - spec/dummy/lib/assets/.keep
343
+ - spec/dummy/log/.keep
344
+ - spec/dummy/public/404.html
345
+ - spec/dummy/public/422.html
346
+ - spec/dummy/public/500.html
347
+ - spec/dummy/public/favicon.ico
348
+ - spec/fixtures/keys.json
349
+ - spec/fixtures/openid-configuration.json
350
+ - spec/lib/openid_token_proxy/client_spec.rb
351
+ - spec/lib/openid_token_proxy/config_spec.rb
352
+ - spec/lib/openid_token_proxy/error_spec.rb
353
+ - spec/lib/openid_token_proxy/token/authentication_spec.rb
354
+ - spec/lib/openid_token_proxy/token/refresh_spec.rb
355
+ - spec/lib/openid_token_proxy/token_spec.rb
356
+ - spec/lib/openid_token_proxy_spec.rb
357
+ - spec/spec_helper.rb
358
+ - spec/support/env.rb
359
+ - spec/support/fixture.rb