@@ -1,45 +1,45 | |||||
1 | # Mocks out OpenID |
|
1 | # Mocks out OpenID | |
2 | # |
|
2 | # | |
3 | # http://www.northpub.com/articles/2007/04/02/testing-openid-support |
|
3 | # http://www.northpub.com/articles/2007/04/02/testing-openid-support | |
4 |
module OpenIdAuthentication |
|
4 | module OpenIdAuthentication | |
5 |
|
5 | |||
6 | EXTENSION_FIELDS = {'email' => 'user@somedomain.com', |
|
6 | EXTENSION_FIELDS = {'email' => 'user@somedomain.com', | |
7 | 'nickname' => 'cool_user', |
|
7 | 'nickname' => 'cool_user', | |
8 | 'country' => 'US', |
|
8 | 'country' => 'US', | |
9 | 'postcode' => '12345', |
|
9 | 'postcode' => '12345', | |
10 | 'fullname' => 'Cool User', |
|
10 | 'fullname' => 'Cool User', | |
11 | 'dob' => '1970-04-01', |
|
11 | 'dob' => '1970-04-01', | |
12 | 'language' => 'en', |
|
12 | 'language' => 'en', | |
13 |
'timezone' => 'America/New_York'} |
|
13 | 'timezone' => 'America/New_York'} | |
14 |
|
14 | |||
15 | protected |
|
15 | protected | |
16 |
|
16 | |||
17 | def authenticate_with_open_id(identity_url = params[:openid_url], options = {}) #:doc: |
|
17 | def authenticate_with_open_id(identity_url = params[:openid_url], options = {}) #:doc: | |
18 | if User.find_by_identity_url(identity_url) || identity_url.include?('good') |
|
18 | if User.find_by_identity_url(identity_url) || identity_url.include?('good') | |
19 | # Don't process registration fields unless it is requested. |
|
19 | # Don't process registration fields unless it is requested. | |
20 | unless identity_url.include?('blank') || (options[:required].nil? && options[:optional].nil?) |
|
20 | unless identity_url.include?('blank') || (options[:required].nil? && options[:optional].nil?) | |
21 | extension_response_fields = {} |
|
21 | extension_response_fields = {} | |
22 |
|
22 | |||
23 | options[:required].each do |field| |
|
23 | options[:required].each do |field| | |
24 | extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s] |
|
24 | extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s] | |
25 | end unless options[:required].nil? |
|
25 | end unless options[:required].nil? | |
26 |
|
26 | |||
27 | options[:optional].each do |field| |
|
27 | options[:optional].each do |field| | |
28 | extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s] |
|
28 | extension_response_fields[field.to_s] = EXTENSION_FIELDS[field.to_s] | |
29 | end unless options[:optional].nil? |
|
29 | end unless options[:optional].nil? | |
30 | end |
|
30 | end | |
31 |
|
31 | |||
32 | yield Result[:successful], identity_url , extension_response_fields |
|
32 | yield Result[:successful], identity_url , extension_response_fields | |
33 | else |
|
33 | else | |
34 |
logger.info "OpenID authentication failed: #{identity_url}" |
|
34 | logger.info "OpenID authentication failed: #{identity_url}" | |
35 | yield Result[:failed], identity_url, nil |
|
35 | yield Result[:failed], identity_url, nil | |
36 | end |
|
36 | end | |
37 | end |
|
37 | end | |
38 |
|
38 | |||
39 | private |
|
39 | private | |
40 |
|
40 | |||
41 | def add_simple_registration_fields(open_id_response, fields) |
|
41 | def add_simple_registration_fields(open_id_response, fields) | |
42 | open_id_response.add_extension_arg('sreg', 'required', [ fields[:required] ].flatten * ',') if fields[:required] |
|
42 | open_id_response.add_extension_arg('sreg', 'required', [ fields[:required] ].flatten * ',') if fields[:required] | |
43 | open_id_response.add_extension_arg('sreg', 'optional', [ fields[:optional] ].flatten * ',') if fields[:optional] |
|
43 | open_id_response.add_extension_arg('sreg', 'optional', [ fields[:optional] ].flatten * ',') if fields[:optional] | |
44 | end |
|
44 | end | |
45 | end |
|
45 | end |
General Comments 0
You need to be logged in to leave comments.
Login now