oauth2_facebook_grantable 0.5.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 (75) hide show
  1. data/.gitignore +5 -0
  2. data/.rspec +2 -0
  3. data/Gemfile +8 -0
  4. data/LICENSE.txt +19 -0
  5. data/README.md +81 -0
  6. data/Rakefile +1 -0
  7. data/lib/devise/oauth2_facebook_grantable/models/oauth2_facebook_grantable.rb +23 -0
  8. data/lib/devise/oauth2_facebook_grantable/strategies/facebook_grant_type.rb +25 -0
  9. data/lib/devise/oauth2_facebook_grantable/version.rb +5 -0
  10. data/lib/generators/oauth2_facebook_grantable/install_generator.rb +32 -0
  11. data/lib/generators/oauth2_facebook_grantable/templates/migration_add_column.rb +6 -0
  12. data/lib/oauth2_facebook_grantable.rb +43 -0
  13. data/oauth2_facebook_grantable.gemspec +25 -0
  14. data/spec/spec_helper.rb +8 -0
  15. data/tests/.gitignore +15 -0
  16. data/tests/Gemfile +41 -0
  17. data/tests/README.rdoc +261 -0
  18. data/tests/Rakefile +7 -0
  19. data/tests/app/assets/images/rails.png +0 -0
  20. data/tests/app/assets/javascripts/application.js +15 -0
  21. data/tests/app/assets/stylesheets/application.css +13 -0
  22. data/tests/app/controllers/application_controller.rb +3 -0
  23. data/tests/app/helpers/application_helper.rb +2 -0
  24. data/tests/app/mailers/.gitkeep +0 -0
  25. data/tests/app/models/.gitkeep +0 -0
  26. data/tests/app/models/user.rb +12 -0
  27. data/tests/app/views/layouts/application.html.erb +14 -0
  28. data/tests/config.ru +4 -0
  29. data/tests/config/application.rb +59 -0
  30. data/tests/config/boot.rb +6 -0
  31. data/tests/config/database.yml +25 -0
  32. data/tests/config/environment.rb +5 -0
  33. data/tests/config/environments/development.rb +37 -0
  34. data/tests/config/environments/production.rb +67 -0
  35. data/tests/config/environments/test.rb +37 -0
  36. data/tests/config/initializers/backtrace_silencers.rb +7 -0
  37. data/tests/config/initializers/devise.rb +223 -0
  38. data/tests/config/initializers/inflections.rb +15 -0
  39. data/tests/config/initializers/mime_types.rb +5 -0
  40. data/tests/config/initializers/secret_token.rb +7 -0
  41. data/tests/config/initializers/session_store.rb +8 -0
  42. data/tests/config/initializers/wrap_parameters.rb +14 -0
  43. data/tests/config/locales/devise.en.yml +57 -0
  44. data/tests/config/locales/en.yml +5 -0
  45. data/tests/config/routes.rb +61 -0
  46. data/tests/config/yetting.yml +12 -0
  47. data/tests/db/migrate/20120426123002_devise_create_users.rb +49 -0
  48. data/tests/db/migrate/20120426123040_create_devise_oauth2_providable_schema.devise_oauth2_providable.rb +55 -0
  49. data/tests/db/migrate/20120426124308_add_facebook_identifier_to_users.rb +6 -0
  50. data/tests/db/schema.rb +91 -0
  51. data/tests/db/seeds.rb +7 -0
  52. data/tests/doc/README_FOR_APP +2 -0
  53. data/tests/lib/assets/.gitkeep +0 -0
  54. data/tests/lib/tasks/.gitkeep +0 -0
  55. data/tests/log/.gitkeep +0 -0
  56. data/tests/public/404.html +26 -0
  57. data/tests/public/422.html +26 -0
  58. data/tests/public/500.html +25 -0
  59. data/tests/public/favicon.ico +0 -0
  60. data/tests/public/index.html +241 -0
  61. data/tests/public/robots.txt +5 -0
  62. data/tests/script/rails +6 -0
  63. data/tests/test/fixtures/.gitkeep +0 -0
  64. data/tests/test/fixtures/users.yml +26 -0
  65. data/tests/test/functional/.gitkeep +0 -0
  66. data/tests/test/integration/.gitkeep +0 -0
  67. data/tests/test/integration/facebook_oauth_test.rb +69 -0
  68. data/tests/test/performance/browsing_test.rb +12 -0
  69. data/tests/test/test_helper.rb +13 -0
  70. data/tests/test/unit/.gitkeep +0 -0
  71. data/tests/test/unit/user_test.rb +7 -0
  72. data/tests/vendor/assets/javascripts/.gitkeep +0 -0
  73. data/tests/vendor/assets/stylesheets/.gitkeep +0 -0
  74. data/tests/vendor/plugins/.gitkeep +0 -0
  75. metadata +214 -0
@@ -0,0 +1,26 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>The change you wanted was rejected (422)</title>
5
+ <style type="text/css">
6
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
7
+ div.dialog {
8
+ width: 25em;
9
+ padding: 0 4em;
10
+ margin: 4em auto 0 auto;
11
+ border: 1px solid #ccc;
12
+ border-right-color: #999;
13
+ border-bottom-color: #999;
14
+ }
15
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <!-- This file lives in public/422.html -->
21
+ <div class="dialog">
22
+ <h1>The change you wanted was rejected.</h1>
23
+ <p>Maybe you tried to change something you didn't have access to.</p>
24
+ </div>
25
+ </body>
26
+ </html>
@@ -0,0 +1,25 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>We're sorry, but something went wrong (500)</title>
5
+ <style type="text/css">
6
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
7
+ div.dialog {
8
+ width: 25em;
9
+ padding: 0 4em;
10
+ margin: 4em auto 0 auto;
11
+ border: 1px solid #ccc;
12
+ border-right-color: #999;
13
+ border-bottom-color: #999;
14
+ }
15
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <!-- This file lives in public/500.html -->
21
+ <div class="dialog">
22
+ <h1>We're sorry, but something went wrong.</h1>
23
+ </div>
24
+ </body>
25
+ </html>
File without changes
@@ -0,0 +1,241 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Ruby on Rails: Welcome aboard</title>
5
+ <style type="text/css" media="screen">
6
+ body {
7
+ margin: 0;
8
+ margin-bottom: 25px;
9
+ padding: 0;
10
+ background-color: #f0f0f0;
11
+ font-family: "Lucida Grande", "Bitstream Vera Sans", "Verdana";
12
+ font-size: 13px;
13
+ color: #333;
14
+ }
15
+
16
+ h1 {
17
+ font-size: 28px;
18
+ color: #000;
19
+ }
20
+
21
+ a {color: #03c}
22
+ a:hover {
23
+ background-color: #03c;
24
+ color: white;
25
+ text-decoration: none;
26
+ }
27
+
28
+
29
+ #page {
30
+ background-color: #f0f0f0;
31
+ width: 750px;
32
+ margin: 0;
33
+ margin-left: auto;
34
+ margin-right: auto;
35
+ }
36
+
37
+ #content {
38
+ float: left;
39
+ background-color: white;
40
+ border: 3px solid #aaa;
41
+ border-top: none;
42
+ padding: 25px;
43
+ width: 500px;
44
+ }
45
+
46
+ #sidebar {
47
+ float: right;
48
+ width: 175px;
49
+ }
50
+
51
+ #footer {
52
+ clear: both;
53
+ }
54
+
55
+ #header, #about, #getting-started {
56
+ padding-left: 75px;
57
+ padding-right: 30px;
58
+ }
59
+
60
+
61
+ #header {
62
+ background-image: url("assets/rails.png");
63
+ background-repeat: no-repeat;
64
+ background-position: top left;
65
+ height: 64px;
66
+ }
67
+ #header h1, #header h2 {margin: 0}
68
+ #header h2 {
69
+ color: #888;
70
+ font-weight: normal;
71
+ font-size: 16px;
72
+ }
73
+
74
+
75
+ #about h3 {
76
+ margin: 0;
77
+ margin-bottom: 10px;
78
+ font-size: 14px;
79
+ }
80
+
81
+ #about-content {
82
+ background-color: #ffd;
83
+ border: 1px solid #fc0;
84
+ margin-left: -55px;
85
+ margin-right: -10px;
86
+ }
87
+ #about-content table {
88
+ margin-top: 10px;
89
+ margin-bottom: 10px;
90
+ font-size: 11px;
91
+ border-collapse: collapse;
92
+ }
93
+ #about-content td {
94
+ padding: 10px;
95
+ padding-top: 3px;
96
+ padding-bottom: 3px;
97
+ }
98
+ #about-content td.name {color: #555}
99
+ #about-content td.value {color: #000}
100
+
101
+ #about-content ul {
102
+ padding: 0;
103
+ list-style-type: none;
104
+ }
105
+
106
+ #about-content.failure {
107
+ background-color: #fcc;
108
+ border: 1px solid #f00;
109
+ }
110
+ #about-content.failure p {
111
+ margin: 0;
112
+ padding: 10px;
113
+ }
114
+
115
+
116
+ #getting-started {
117
+ border-top: 1px solid #ccc;
118
+ margin-top: 25px;
119
+ padding-top: 15px;
120
+ }
121
+ #getting-started h1 {
122
+ margin: 0;
123
+ font-size: 20px;
124
+ }
125
+ #getting-started h2 {
126
+ margin: 0;
127
+ font-size: 14px;
128
+ font-weight: normal;
129
+ color: #333;
130
+ margin-bottom: 25px;
131
+ }
132
+ #getting-started ol {
133
+ margin-left: 0;
134
+ padding-left: 0;
135
+ }
136
+ #getting-started li {
137
+ font-size: 18px;
138
+ color: #888;
139
+ margin-bottom: 25px;
140
+ }
141
+ #getting-started li h2 {
142
+ margin: 0;
143
+ font-weight: normal;
144
+ font-size: 18px;
145
+ color: #333;
146
+ }
147
+ #getting-started li p {
148
+ color: #555;
149
+ font-size: 13px;
150
+ }
151
+
152
+
153
+ #sidebar ul {
154
+ margin-left: 0;
155
+ padding-left: 0;
156
+ }
157
+ #sidebar ul h3 {
158
+ margin-top: 25px;
159
+ font-size: 16px;
160
+ padding-bottom: 10px;
161
+ border-bottom: 1px solid #ccc;
162
+ }
163
+ #sidebar li {
164
+ list-style-type: none;
165
+ }
166
+ #sidebar ul.links li {
167
+ margin-bottom: 5px;
168
+ }
169
+
170
+ .filename {
171
+ font-style: italic;
172
+ }
173
+ </style>
174
+ <script type="text/javascript">
175
+ function about() {
176
+ info = document.getElementById('about-content');
177
+ if (window.XMLHttpRequest)
178
+ { xhr = new XMLHttpRequest(); }
179
+ else
180
+ { xhr = new ActiveXObject("Microsoft.XMLHTTP"); }
181
+ xhr.open("GET","rails/info/properties",false);
182
+ xhr.send("");
183
+ info.innerHTML = xhr.responseText;
184
+ info.style.display = 'block'
185
+ }
186
+ </script>
187
+ </head>
188
+ <body>
189
+ <div id="page">
190
+ <div id="sidebar">
191
+ <ul id="sidebar-items">
192
+ <li>
193
+ <h3>Browse the documentation</h3>
194
+ <ul class="links">
195
+ <li><a href="http://guides.rubyonrails.org/">Rails Guides</a></li>
196
+ <li><a href="http://api.rubyonrails.org/">Rails API</a></li>
197
+ <li><a href="http://www.ruby-doc.org/core/">Ruby core</a></li>
198
+ <li><a href="http://www.ruby-doc.org/stdlib/">Ruby standard library</a></li>
199
+ </ul>
200
+ </li>
201
+ </ul>
202
+ </div>
203
+
204
+ <div id="content">
205
+ <div id="header">
206
+ <h1>Welcome aboard</h1>
207
+ <h2>You&rsquo;re riding Ruby on Rails!</h2>
208
+ </div>
209
+
210
+ <div id="about">
211
+ <h3><a href="rails/info/properties" onclick="about(); return false">About your application&rsquo;s environment</a></h3>
212
+ <div id="about-content" style="display: none"></div>
213
+ </div>
214
+
215
+ <div id="getting-started">
216
+ <h1>Getting started</h1>
217
+ <h2>Here&rsquo;s how to get rolling:</h2>
218
+
219
+ <ol>
220
+ <li>
221
+ <h2>Use <code>rails generate</code> to create your models and controllers</h2>
222
+ <p>To see all available options, run it without parameters.</p>
223
+ </li>
224
+
225
+ <li>
226
+ <h2>Set up a default route and remove <span class="filename">public/index.html</span></h2>
227
+ <p>Routes are set up in <span class="filename">config/routes.rb</span>.</p>
228
+ </li>
229
+
230
+ <li>
231
+ <h2>Create your database</h2>
232
+ <p>Run <code>rake db:create</code> to create your database. If you're not using SQLite (the default), edit <span class="filename">config/database.yml</span> with your username and password.</p>
233
+ </li>
234
+ </ol>
235
+ </div>
236
+ </div>
237
+
238
+ <div id="footer">&nbsp;</div>
239
+ </div>
240
+ </body>
241
+ </html>
@@ -0,0 +1,5 @@
1
+ # See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file
2
+ #
3
+ # To ban all spiders from the entire site uncomment the next two lines:
4
+ # User-Agent: *
5
+ # Disallow: /
@@ -0,0 +1,6 @@
1
+ #!/usr/bin/env ruby
2
+ # This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
3
+
4
+ APP_PATH = File.expand_path('../../config/application', __FILE__)
5
+ require File.expand_path('../../config/boot', __FILE__)
6
+ require 'rails/commands'
File without changes
@@ -0,0 +1,26 @@
1
+ # Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html
2
+
3
+ # This model initially had no columns defined. If you add columns to the
4
+ # model remove the '{}' from the fixture names and add the columns immediately
5
+ # below each fixture, per the syntax in the comments below
6
+ #
7
+ #one: {}
8
+ # column: value
9
+ #
10
+ #two: {}
11
+ # column: value
12
+
13
+ admin:
14
+ email: "admin@example.com"
15
+ encrypted_password: "app123"
16
+
17
+ user:
18
+ email: "user@example.com"
19
+ encrypted_password: "app123"
20
+
21
+ disabled:
22
+ email: "disabled@example.com"
23
+ encrypted_password: "app123"
24
+
25
+ facebook:
26
+ email: "facebookuser@fb.com"
File without changes
File without changes
@@ -0,0 +1,69 @@
1
+ ENV["RAILS_ENV"] = "test"
2
+ require File.expand_path('../../../config/environment', __FILE__)
3
+ require 'rails/test_help'
4
+
5
+ class FacebookOauthTest < ActionDispatch::IntegrationTest
6
+ fixtures :all
7
+
8
+ def setup
9
+ # Create a test client
10
+ @client = Devise::Oauth2Providable::Client.create(:name => "Test Client", :redirect_uri => "test://test", :website => "http://test/")
11
+ @client.save
12
+
13
+ # Setup a default user
14
+ @user = users(:user)
15
+
16
+ # Get facebook application credentials
17
+ fb_key = Yetting.facebook_api_key
18
+ fb_secret = Yetting.facebook_api_secret
19
+
20
+ # Create test users
21
+ @test_users = Koala::Facebook::TestUsers.new(:app_id => fb_key, :secret => fb_secret)
22
+ @fb_user = @test_users.create(true, "read_stream")
23
+ @other_fb_user = @test_users.create(true, "read_stream")
24
+
25
+ # Associate the facebook user with the default user
26
+ @user.facebook_identifier = @fb_user["id"]
27
+ @user.save
28
+ end
29
+
30
+ def teardown
31
+ @client.destroy
32
+ @test_users.delete(@fb_user)
33
+ @test_users.delete(@other_fb_user)
34
+ end
35
+
36
+ test "Authenticate with valide facebook token" do
37
+ post_via_redirect("/oauth/token",
38
+ :format => :json,
39
+ :facebook_identifier => @fb_user["id"],
40
+ :facebook_access_token => @fb_user["access_token"],
41
+ :grant_type => "facebook",
42
+ :client_secret => @client.secret,
43
+ :client_id => @client.identifier)
44
+ assert_response :ok
45
+ end
46
+
47
+ test "Authenticate with invalid facebook token" do
48
+ post_via_redirect("/oauth/token",
49
+ :format => :json,
50
+ :facebook_identifier => @fb_user["id"],
51
+ :facebook_access_token => "NOTAVALIDTOKEN",
52
+ :grant_type => "facebook",
53
+ :client_secret => @client.secret,
54
+ :client_id => @client.identifier)
55
+ assert_response :bad_request
56
+ end
57
+
58
+ test "Authenticate with valid token but invalid id" do
59
+ post_via_redirect("/oauth/token",
60
+ :format => :json,
61
+ :facebook_identifier => @other_fb_user["id"],
62
+ :facebook_access_token => @fb_user["access_token"],
63
+ :grant_type => "facebook",
64
+ :client_secret => @client.secret,
65
+ :client_id => @client.identifier)
66
+ assert_response :bad_request
67
+ end
68
+
69
+ end
@@ -0,0 +1,12 @@
1
+ require 'test_helper'
2
+ require 'rails/performance_test_help'
3
+
4
+ class BrowsingTest < ActionDispatch::PerformanceTest
5
+ # Refer to the documentation for all available options
6
+ # self.profile_options = { :runs => 5, :metrics => [:wall_time, :memory]
7
+ # :output => 'tmp/performance', :formats => [:flat] }
8
+
9
+ def test_homepage
10
+ get '/'
11
+ end
12
+ end
@@ -0,0 +1,13 @@
1
+ ENV["RAILS_ENV"] = "test"
2
+ require File.expand_path('../../config/environment', __FILE__)
3
+ require 'rails/test_help'
4
+
5
+ class ActiveSupport::TestCase
6
+ # Setup all fixtures in test/fixtures/*.(yml|csv) for all tests in alphabetical order.
7
+ #
8
+ # Note: You'll currently still have to declare fixtures explicitly in integration tests
9
+ # -- they do not yet inherit this setting
10
+ fixtures :all
11
+
12
+ # Add more helper methods to be used by all tests here...
13
+ end