A valuable lesson in the Facebook API
Update 2021: This post mentions deprecated Facebook API calls and concepts
So – A client wanted to enable users to pick a friend from Facebook and buy them a birthday-present on their e-Commerce site.
Being sort of a n00b in the world of Facebook i thought Hey – that’s just a question of creating a Facebook App and list the friends using FQL that would pick friends and their birthdays. It looks something like:
SELECT uid,name,first_name,middle_name,last_name,sex,birthday_date  FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = me()) AND birthday_date <> '' ORDER BY substr(birthday_date, 0,5)
I did it – and it worked. For me. And for me only. Huh? Yep – just for me.
Permission seemed adequate. It was indeed a mystery, until i actually *RTFM*. The top of this screen clearly states:
Use these settings to enter the set of permissions your app requires when displayed in App-center or using Auth Referrals
which apparently has nothing to do with what my app could do at the website. My click handler to perform the login now looks like this:
$('.eg_facebook_login').live('click', function() { FB.login(function(response) { if (response.authResponse) { FB.api('/me', function(response) { // .. get fb friend list }); } else { console.log('User cancelled login or did not fully authorize.'); } }, {scope:'user_about_me,user_birthday,friends_about_me,friends_birthday,friends_photos}); });
Turns out FB.login is unaware of the permissions set in my app, so I specifically have to ask for them at login using the scope-part of the opts-object. FB.login actually has documentation.
Add your own comment