2

I'm copy and pasting the code from Heroku's tutorial about building a canvas app to host on Heroku seen here. https://devcenter.heroku.com/articles/facebook-ruby However, I'm getting this error which the backtrace (see below) says is related to omniauth.

Can anyone explain

NoMethodError at /
undefined method `include?' for nil:NilClass
file: builder.rb location: call line: 29

These are the gems it uses

gem 'sinatra', '1.0'
gem 'oa-oauth', '0.1.6'



BACKTRACE
(condense)
JUMP TO: GET POST COOKIES ENV
/Users/michael/.rvm/gems/ruby-1.9.3-rc1@ruby193/gems/oa-core-0.1.6/lib/omniauth/builder.rb in call
      @ins << @app unless @ins.include?(@app)
/Users/michael/.rvm/gems/ruby-1.9.3-rc1@ruby193/gems/rack-protection-1.2.0/lib/rack/protection/xss_header.rb in call
        status, headers, body = @app.call(env)
/Users/michael/.rvm/gems/ruby-1.9.3-rc1@ruby193/gems/rack-protection-1.2.0/lib/rack/protection/base.rb in call
        result or app.call(env)
/Users/michael/.rvm/gems/ruby-1.9.3-rc1@ruby193/gems/rack-protection-1.2.0/lib/rack/protection/base.rb in call
        result or app.call(env)
/Users/michael/.rvm/gems/ruby-1.9.3-rc1@ruby193/gems/rack-protection-1.2.0/lib/rack/protection/path_traversal.rb in call

Main code

index.erb

<%=session['fb_error']%>

<% if session['fb_auth'] %>
  <a href='logout'><img src='images/fb_logout_button.png'></a>
<% else %>
  <a href='auth/facebook'><img src='images/fb_login_button.png'></a>
<% end %>

<h3><%= 'Hello, ' + session['fb_auth']['user_info']['first_name'] + ', ' if session['fb_token'] %>Welcome to my list of interesting articles.</h3>

<table>
  <% @articles.each do |article| %>
  <tr>
    <td class='article'>- <a href='<%=article[:url]%>' target='_blank'><%=article[:title]%></a></td>
    <td>
      <% if session['fb_auth'] %>
        <iframe src="http://www.facebook.com/plugins/like.php?href=<%=article[:url]%>&amp;layout=button_count&amp;show_faces=true&amp;width=450&amp;action=like&amp;colorscheme=light&amp;height=21" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:450px; height:21px;" allowTransparency="true"></iframe>
      <% end %>
    </td>
  </tr>
  <% end %>
</table>

<% if session['fb_auth'] %>
  <hr />
  <p><span class='like_site'>Do you like this site?</span></p>
  <p><iframe src="http://www.facebook.com/plugins/like.php?href=http%3A%2F%2Ffaceboku.heroku.com%2F&amp;layout=standard&amp;show_faces=true&amp;width=450&amp;action=like&amp;colorscheme=light&amp;height=80" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:450px; height:80px;" allowTransparency="true"></iframe></p>
<% end %>

Faceboku.rb

equire 'sinatra'
require 'omniauth/oauth'

enable :sessions


#Here you have to put your own Application ID and Secret
APP_ID = "495940167082961"
APP_SECRET = "686da25c0fdd04a6f61b287bb0d5c9aa"

use OmniAuth::Builder do
  provider :facebook, APP_ID, APP_SECRET, { :scope => 'email, status_update, publish_stream' }
end

get '/' do
    @articles = []
    @articles << {:title => 'Deploying Rack-based apps in Heroku', :url => 'http://docs.heroku.com/rack'}
    @articles << {:title => 'Learn Ruby in twenty minutes', :url => 'http://www.ruby-lang.org/en/documentation/quickstart/'}

    erb :index
end

get '/auth/facebook/callback' do
  session['fb_auth'] = request.env['omniauth.auth']
  session['fb_token'] = session['fb_auth']['credentials']['token']
  session['fb_error'] = nil
  redirect '/'
end

get '/auth/failure' do
  clear_session
  session['fb_error'] = 'In order to use this site you must allow us access to your Facebook data<br />'
  redirect '/'
end

get '/logout' do
  clear_session
  redirect '/'
end

def clear_session
  session['fb_auth'] = nil
  session['fb_token'] = nil
  session['fb_error'] = nil
end
Leahcim
  • 40,649
  • 59
  • 195
  • 334
  • 2nding this, I'm following the tutorial as well and can't get it working. It seems to be bundler is having trouble finding the omniauth gem. – Harry Moreno Mar 19 '13 at 22:05
  • It seems to be Omniauth's builder class is choking on an @ins variable that may be environment dependent. – Harry Moreno Mar 19 '13 at 22:14
  • Hey, guys, I wrote that tutorial, I haven't had time to review it and update it, but I'll do it soon, please, be patient. I will let you guys know through this post when it's updated. Thanks! – raf Mar 24 '13 at 20:36
  • 4
    Hey, I've updated the tuto and the code, everything seems to be working now, please, let me know if it doesn't. it doesn't show some images because I need to wait for Heroku's approval but it works anyways: https://devcenter.heroku.com/articles/facebook-ruby – raf Mar 26 '13 at 02:25
  • @raf - If you're game to recap the solution as your own answer, I'll delete my answer. (See http://meta.stackexchange.com/questions/90263/unanswered-question-answered-in-comments for elaboration of why this is helpful.) Thanks! – DreadPirateShawn Oct 09 '13 at 16:27

1 Answers1

1

Copying the answer from the comments in order to remove this question from the "Unanswered" filter:

Hey, guys, I wrote that tutorial ... I've updated the tuto and the code, everything seems to be working now, please, let me know if it doesn't. it doesn't show some images because I need to wait for Heroku's approval but it works anyways: https://devcenter.heroku.com/articles/facebook-ruby

~ answer per raf

Community
  • 1
  • 1
DreadPirateShawn
  • 8,164
  • 4
  • 49
  • 71