authorizme 0.0.10 → 0.0.11

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.
data/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## 0.0.11
2
+
3
+ ### Features & Enhancements
4
+
5
+ * Facebook provider update
6
+ * Refacturing
7
+
1
8
  ## 0.0.10
2
9
 
3
10
  ### Features & Enhancements
@@ -1,44 +1,47 @@
1
1
  module Authorizme
2
2
  module Login
3
3
  class FacebookController < AuthorizmeController
4
-
4
+ before_filter :set_facebook, :only => [:auth, :callback, :canvas]
5
+
5
6
  def auth
6
- redirect_to client.authorization.authorize_url(:redirect_uri => redirect_uri("facebook"),
7
- :scope => Authorizme::facebook_perms,
8
- :display => "popup")
7
+ callback_url = params[:callback_url] || redirect_uri("facebook")
8
+ if params[:canvas]
9
+ @authorize_url = @facebook.get_dialog_authorize_url callback_url, Authorizme::facebook_perms
10
+ else
11
+ redirect_to @facebook.get_popup_authorize_url callback_url, Authorizme::facebook_perms
12
+ end
9
13
  end
10
14
 
11
15
  def callback
12
- @facebook = Authorizme::Provider::Facebook.new(code: params[:code], redirect_uri: redirect_uri("facebook"))
13
- authorize_user @facebook.get_client, @facebook.get_access_token
14
- render_popup_view
15
- end
16
-
17
- def canvas
18
- @facebook = Authorizme::Provider::Facebook.new(signed_request: params[:signed_request])
19
- user = authorize_user @facebook.get_client, @facebook.get_access_token
20
- redirect_to Authorizme::after_login_path
16
+ if params[:signed_request]
17
+ @facebook.authorize_with_signed_request params[:signed_request]
18
+ authorize_user @facebook
19
+ redirect_to Authorizme::after_login_path
20
+ elsif params[:code]
21
+ @facebook.authorize_with_code params[:code], redirect_uri("facebook")
22
+ authorize_user @facebook
23
+ render_popup_view
24
+ else
25
+ redirect_to Authorizme::after_login_path
26
+ end
21
27
  end
22
28
 
23
29
  private
24
-
25
- def client token = nil
26
- options = {client_id: Authorizme::facebook_client_id, secret_id: Authorizme::facebook_client_secret}
27
- options[:token] = token if token
28
- @client ||= FBGraph::Client.new(options)
30
+
31
+ def set_facebook
32
+ options = {client_id: Authorizme::facebook_client_id, client_secret: Authorizme::facebook_client_secret}
33
+ @facebook = Authorizme::Provider::Facebook.new(options)
29
34
  end
30
35
 
31
- def authorize_user client, access_token
32
- user_json = client.selection.me.info!
33
- image_url = "https://graph.facebook.com/#{user_json.id}/picture?type=large"
34
- attributes = {first_name: user_json.first_name, last_name: user_json.last_name, image_url: image_url}
35
- if user_json.email
36
- user = User.find_by_email(user_json.email)
37
- unless user
38
- attributes[:email] = user_json.email
36
+ def authorize_user facebook
37
+ fb_user = facebook.get_user
38
+ if fb_user[:email]
39
+ user = User.find_by_email(fb_user[:email])
40
+ if user
41
+ fb_user.delete(:email)
39
42
  end
40
43
  end
41
- user = User.authenticate_with_facebook(user_json.id, attributes, access_token)
44
+ user = User.authenticate_with_facebook(facebook.get_user_json.id, fb_user, facebook.get_access_token)
42
45
  login user
43
46
  user
44
47
  end
@@ -0,0 +1,4 @@
1
+ <script>
2
+ var oauth_url = "<%= @authorize_url %>";
3
+ window.top.location = oauth_url.replace("&amp;","&");
4
+ </script>
data/config/routes.rb CHANGED
@@ -12,8 +12,6 @@ Rails.application.routes.draw do
12
12
  get "/login/#{provider}" => "login/#{provider}#auth", :as => "#{provider}_login"
13
13
  get "/login/#{provider}/callback" => "login/#{provider}#callback", :as => "#{provider}_callback"
14
14
  end
15
-
16
- post "/login/facebook/canvas" => "login/facebook#canvas", :as => "facebook_canvas"
17
15
 
18
16
  post '/login' => 'sessions#create', :as => 'login'
19
17
  get '/logout' => 'sessions#destroy', :as => 'logout'
@@ -19,8 +19,6 @@ module Authorizme
19
19
  end
20
20
 
21
21
  def login_url
22
- puts "App key: #{@options[:draugiem_app_key]}"
23
- puts "Redirect url: #{@options[:redirect_url]}"
24
22
  hash = Digest::MD5.hexdigest(@options[:draugiem_app_key] + @options[:redirect_url])
25
23
  "#{@options[:draugiem_api_authorize_path]}?app=#{@options[:draugiem_app_id]}&hash=#{hash}&redirect=#{@options[:redirect_url]}"
26
24
  end
@@ -7,22 +7,8 @@ module Authorizme
7
7
  attr_accessor :options
8
8
 
9
9
  def initialize(options={})
10
- @options = {client_id: Authorizme::facebook_client_id, secret_id: Authorizme::facebook_client_secret}.merge(options)
11
- set_client
12
- end
13
-
14
- def set_client
15
- options = {client_id: Authorizme::facebook_client_id, secret_id: Authorizme::facebook_client_secret}
16
- @client ||= FBGraph::Client.new(options)
17
- @access_token = nil
18
- if @options[:code] && @options[:redirect_uri]
19
- @access_token = @client.authorization.process_callback(@options[:code], :redirect_uri => @options[:redirect_uri])
20
- elsif @options[:signed_request]
21
- data = FBGraph::Canvas.parse_signed_request(@options[:secret_id], @options[:signed_request])
22
- @access_token = data["oauth_token"]
23
- @client.set_token @access_token
24
- end
25
- @client
10
+ @options = options
11
+ init_client
26
12
  end
27
13
 
28
14
  def get_client
@@ -33,18 +19,58 @@ module Authorizme
33
19
  @access_token
34
20
  end
35
21
 
36
- def get_facebook_user
37
- user_json = get_facebook_user_json
22
+ def get_user_json
23
+ @user_json ||= @client.selection.me.info!
24
+ end
25
+
26
+ def get_user
27
+ user_json = get_user_json
38
28
  image_url = "https://graph.facebook.com/#{user_json.id}/picture?type=large"
39
29
  attributes = {first_name: user_json.first_name, last_name: user_json.last_name, image_url: image_url, email: user_json.email}
40
30
  end
41
31
 
42
- def get_facebook_user_json
43
- @user_json ||= @client.selection.me.info!
32
+ def get_signed_request_data
33
+ if @signed_request_data
34
+ return @signed_request_data
35
+ else
36
+ return nil
37
+ end
38
+ end
39
+
40
+ def authorize_with_code code, redirect_uri
41
+ @access_token = @client.authorization.process_callback(code, :redirect_uri => redirect_uri)
42
+ return @access_token != nil
43
+ end
44
+
45
+ def authorize_with_signed_request signed_request
46
+ @signed_request_data = FBGraph::Canvas.parse_signed_request(@options[:client_secret], signed_request)
47
+ @access_token = @signed_request_data["oauth_token"] if @signed_request_data["oauth_token"]
48
+ @client.set_token @access_token if @client
49
+ return @access_token != nil
50
+ end
51
+
52
+ def get_popup_authorize_url callback_url, scope
53
+ @client.authorization.authorize_url(:redirect_uri => callback_url,
54
+ :scope => scope,
55
+ :display => "popup")
56
+ end
57
+
58
+ def get_dialog_authorize_url callback_url, scope
59
+ "https://www.facebook.com/dialog/oauth/?client_id=#{@options[:client_id]}&redirect_uri=#{CGI.escape(callback_url)}&scope=#{scope}"
44
60
  end
45
61
 
46
62
  private
47
63
 
64
+ def init_client
65
+ @client = nil
66
+ @access_token = nil
67
+ if @options[:client_id] && @options[:client_secret]
68
+ options = {client_id: @options[:client_id], secret_id: @options[:client_secret]}
69
+ @client = FBGraph::Client.new(options)
70
+ end
71
+ @client
72
+ end
73
+
48
74
  end
49
75
  end
50
76
  end
@@ -1,3 +1,3 @@
1
1
  module Authorizme
2
- VERSION = "0.0.10"
2
+ VERSION = "0.0.11"
3
3
  end
@@ -6,7 +6,13 @@ class CreateUserRoles < ActiveRecord::Migration
6
6
  t.timestamps
7
7
  end
8
8
 
9
- Authorizme::UserRole.create!(:name => 'member')
9
+ member_role = Authorizme::UserRole.new
10
+ member_role.name = "member"
11
+ member_role.save!
12
+
13
+ admin_role = Authorizme::UserRole.new
14
+ admin_role.name = "admin"
15
+ admin_role.save!
10
16
  end
11
17
 
12
18
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: authorizme
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.10
4
+ version: 0.0.11
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -10,11 +10,11 @@ authors:
10
10
  autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2012-06-21 00:00:00.000000000 Z
13
+ date: 2012-06-26 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: rake
17
- requirement: &82723910 !ruby/object:Gem::Requirement
17
+ requirement: &73618960 !ruby/object:Gem::Requirement
18
18
  none: false
19
19
  requirements:
20
20
  - - ! '>='
@@ -22,10 +22,10 @@ dependencies:
22
22
  version: '0'
23
23
  type: :development
24
24
  prerelease: false
25
- version_requirements: *82723910
25
+ version_requirements: *73618960
26
26
  - !ruby/object:Gem::Dependency
27
27
  name: rspec
28
- requirement: &82723200 !ruby/object:Gem::Requirement
28
+ requirement: &73617750 !ruby/object:Gem::Requirement
29
29
  none: false
30
30
  requirements:
31
31
  - - ! '>='
@@ -33,10 +33,10 @@ dependencies:
33
33
  version: '0'
34
34
  type: :development
35
35
  prerelease: false
36
- version_requirements: *82723200
36
+ version_requirements: *73617750
37
37
  - !ruby/object:Gem::Dependency
38
38
  name: rspec-rails
39
- requirement: &82722570 !ruby/object:Gem::Requirement
39
+ requirement: &73616730 !ruby/object:Gem::Requirement
40
40
  none: false
41
41
  requirements:
42
42
  - - ! '>='
@@ -44,10 +44,10 @@ dependencies:
44
44
  version: '0'
45
45
  type: :development
46
46
  prerelease: false
47
- version_requirements: *82722570
47
+ version_requirements: *73616730
48
48
  - !ruby/object:Gem::Dependency
49
49
  name: webrat
50
- requirement: &82722270 !ruby/object:Gem::Requirement
50
+ requirement: &73615080 !ruby/object:Gem::Requirement
51
51
  none: false
52
52
  requirements:
53
53
  - - ! '>='
@@ -55,10 +55,10 @@ dependencies:
55
55
  version: '0'
56
56
  type: :development
57
57
  prerelease: false
58
- version_requirements: *82722270
58
+ version_requirements: *73615080
59
59
  - !ruby/object:Gem::Dependency
60
60
  name: capybara
61
- requirement: &80394650 !ruby/object:Gem::Requirement
61
+ requirement: &73613250 !ruby/object:Gem::Requirement
62
62
  none: false
63
63
  requirements:
64
64
  - - ! '>='
@@ -66,10 +66,10 @@ dependencies:
66
66
  version: '0'
67
67
  type: :development
68
68
  prerelease: false
69
- version_requirements: *80394650
69
+ version_requirements: *73613250
70
70
  - !ruby/object:Gem::Dependency
71
71
  name: factory_girl_rails
72
- requirement: &80394430 !ruby/object:Gem::Requirement
72
+ requirement: &73612250 !ruby/object:Gem::Requirement
73
73
  none: false
74
74
  requirements:
75
75
  - - ! '>='
@@ -77,10 +77,10 @@ dependencies:
77
77
  version: '0'
78
78
  type: :development
79
79
  prerelease: false
80
- version_requirements: *80394430
80
+ version_requirements: *73612250
81
81
  - !ruby/object:Gem::Dependency
82
82
  name: activesupport
83
- requirement: &80394200 !ruby/object:Gem::Requirement
83
+ requirement: &73611560 !ruby/object:Gem::Requirement
84
84
  none: false
85
85
  requirements:
86
86
  - - ! '>='
@@ -88,10 +88,10 @@ dependencies:
88
88
  version: '0'
89
89
  type: :runtime
90
90
  prerelease: false
91
- version_requirements: *80394200
91
+ version_requirements: *73611560
92
92
  - !ruby/object:Gem::Dependency
93
93
  name: rails
94
- requirement: &80393980 !ruby/object:Gem::Requirement
94
+ requirement: &73627140 !ruby/object:Gem::Requirement
95
95
  none: false
96
96
  requirements:
97
97
  - - ! '>='
@@ -99,10 +99,10 @@ dependencies:
99
99
  version: '0'
100
100
  type: :runtime
101
101
  prerelease: false
102
- version_requirements: *80393980
102
+ version_requirements: *73627140
103
103
  - !ruby/object:Gem::Dependency
104
104
  name: bcrypt-ruby
105
- requirement: &80393750 !ruby/object:Gem::Requirement
105
+ requirement: &73626440 !ruby/object:Gem::Requirement
106
106
  none: false
107
107
  requirements:
108
108
  - - ! '>='
@@ -110,10 +110,10 @@ dependencies:
110
110
  version: '0'
111
111
  type: :runtime
112
112
  prerelease: false
113
- version_requirements: *80393750
113
+ version_requirements: *73626440
114
114
  - !ruby/object:Gem::Dependency
115
115
  name: json
116
- requirement: &80393530 !ruby/object:Gem::Requirement
116
+ requirement: &73624260 !ruby/object:Gem::Requirement
117
117
  none: false
118
118
  requirements:
119
119
  - - ! '>='
@@ -121,10 +121,10 @@ dependencies:
121
121
  version: '0'
122
122
  type: :runtime
123
123
  prerelease: false
124
- version_requirements: *80393530
124
+ version_requirements: *73624260
125
125
  - !ruby/object:Gem::Dependency
126
126
  name: twitter_oauth
127
- requirement: &80393300 !ruby/object:Gem::Requirement
127
+ requirement: &73620970 !ruby/object:Gem::Requirement
128
128
  none: false
129
129
  requirements:
130
130
  - - ! '>='
@@ -132,10 +132,10 @@ dependencies:
132
132
  version: '0'
133
133
  type: :runtime
134
134
  prerelease: false
135
- version_requirements: *80393300
135
+ version_requirements: *73620970
136
136
  - !ruby/object:Gem::Dependency
137
137
  name: twitter
138
- requirement: &80393080 !ruby/object:Gem::Requirement
138
+ requirement: &73635230 !ruby/object:Gem::Requirement
139
139
  none: false
140
140
  requirements:
141
141
  - - ! '>='
@@ -143,10 +143,10 @@ dependencies:
143
143
  version: '0'
144
144
  type: :runtime
145
145
  prerelease: false
146
- version_requirements: *80393080
146
+ version_requirements: *73635230
147
147
  - !ruby/object:Gem::Dependency
148
148
  name: oauth2
149
- requirement: &80392850 !ruby/object:Gem::Requirement
149
+ requirement: &73630450 !ruby/object:Gem::Requirement
150
150
  none: false
151
151
  requirements:
152
152
  - - ! '>='
@@ -154,10 +154,10 @@ dependencies:
154
154
  version: '0'
155
155
  type: :runtime
156
156
  prerelease: false
157
- version_requirements: *80392850
157
+ version_requirements: *73630450
158
158
  - !ruby/object:Gem::Dependency
159
159
  name: fbgraph
160
- requirement: &80392630 !ruby/object:Gem::Requirement
160
+ requirement: &73629500 !ruby/object:Gem::Requirement
161
161
  none: false
162
162
  requirements:
163
163
  - - ! '>='
@@ -165,7 +165,7 @@ dependencies:
165
165
  version: '0'
166
166
  type: :runtime
167
167
  prerelease: false
168
- version_requirements: *80392630
168
+ version_requirements: *73629500
169
169
  description: Authorization that includes basic authorization and 3 social authorization
170
170
  with Latvia social network draugiem.lv, facebook.com and twitter.com.
171
171
  email:
@@ -196,6 +196,7 @@ files:
196
196
  - app/views/authorizme/authorizme/popup.html.erb
197
197
  - app/views/authorizme/layouts/authorizme.html.erb
198
198
  - app/views/authorizme/layouts/popup.html.erb
199
+ - app/views/authorizme/login/facebook/auth.html.erb
199
200
  - app/views/authorizme/users/new.html.erb
200
201
  - authorizme.gemspec
201
202
  - config/routes.rb
@@ -238,7 +239,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
238
239
  version: '0'
239
240
  segments:
240
241
  - 0
241
- hash: 657610419
242
+ hash: -176114737
242
243
  required_rubygems_version: !ruby/object:Gem::Requirement
243
244
  none: false
244
245
  requirements:
@@ -247,7 +248,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
247
248
  version: '0'
248
249
  segments:
249
250
  - 0
250
- hash: 657610419
251
+ hash: -176114737
251
252
  requirements: []
252
253
  rubyforge_project: authorizme
253
254
  rubygems_version: 1.8.15