Get each post id with all comments using facebook FQL - facebook-graph-api

i want to get each post id with all comments for a page using fql query.if i use -
SELECT text,post_id FROM comment WHERE post_id IN(SELECT post_id FROM stream WHERE source_id=page_id_here)
this returns -
{
"data": [
{
"text": "Would be nice if my website would let me do the update. It says I have the most current version 2.5.9 :(",
"post_id": "2211155996_10151336546425997"
},
{
"text": "All of mine just started showing the update message in the last hour and just got the emails from Admin tools.",
"post_id": "2211155996_10151336546425997"
},
........continues
as you see it returns text and post_id in one object.what i want is there will be post_id and its all comments in one object.hope i get answer as i am struggling for a hour.It's something to do with multi queries with join

Related

Facebook Graph API feed not working

I'm completely new to Facebook Graph API.
I'm trying to use the Graph API Explorer: https://developers.facebook.com/tools/explorer/
I got the token, I'm using GET method and version 2.5 of FQL, and following is the query itself:
me?fields=id,name,picture,feed
The result from that query unfortunately only includes the id, name and picture but does not include the posts. I also tried to write "posts" instead of "feed", but the result was the same.
This is what I get:
{
"id": "123456789",
"name": "John Smith",
"picture": {
"data": {
"is_silhouette": false,
"url": "https://fbcdn-profile-a.akamaihd.net/very-long-url"
}
}
}
As you can see, nothing about the posts.
I also tried to open a new Chrome tab and go directly to this URL:
https://graph.facebook.com/me/feed?access_token=very-long-token
And this is what I get for that:
{
"data": [
]
}
What am I doing wrong?
Any help will be profoundly appreciated!
Did you try with user_posts permission?
Maybe you forgot this...
https://developers.facebook.com/docs/graph-api/reference/v2.6/user/feed
Your app needs user_posts permission from the person who created the
post or the person tagged in the post. Then your app can read:
Timeline posts from the person who gave you the permission. The posts
that other people made on that person Timeline. The posts that other
people have tagged that person in.
Cheers

How to use Facebook graph API query correctly

i am a new comer .Someone suggested me that i will get a solution of my question from this site.So that's why i am posting my question in here.
When i used this facebook fql query:
http://graph.facebook.com/fql?q=SELECT+like_info+FROM+photo+WHERE+object_id=723217944369470
Answer was:
{
"data": [
{
"like_info": {
"can_like": false,
"like_count": 7,
"user_likes": false
}
}
]
}
But when i used this facebook fql query:
http://graph.facebook.com/fql?q=SELECT+like_info+FROM+stream+WHERE+post_id=488253731301614
Answer was:
{
"data": [
]
}
Why?and how to query correctly to get a post's like info?
In graph API, you can do something like this to get a post's likes:
https://graph.facebook.com/POST_ID/likes?access_token=ACCESS_TOKEN
You need to replace POST_ID and ACCESS_TOKEN with actual values.
You can use Graph API Explorer to generate an access_token
https://developers.facebook.com/tools/explorer/ (don' forgot asking for sufficient permission to view the post in question).

display most commented (on facebook) "article"

i have set of articles on my website where people can comment using facebook.
The fix is I have to find the most commented article and show, say 5 of them, on webpage.
I have tried looking into facebook api, and googled it out for 2-3 days without having any luck.please help
You can query this info from the Facebook API - I'll explain the process to do it, but I'm not a django expert, so you'll need to turn this into Python.
Basically, you need to grab the URLs for each of your articles and hit the Graph API requesting the comments and a summary of them for that URL like this: https://graph.facebook.com/comments/?ids=YOUR-URL&summary=1
Change the YOUR-URL part of the above to the link you want to check. You can even specify more than one link at at time if you like: https://graph.facebook.com/comments/?ids=YOUR-URL1,YOUR-URL2&summary=1
So if you query the example.com comments:
Hit this URL https://graph.facebook.com/comments/?ids=http://example.com/comments&summary=1
You should get back some JSON data which looks like this (I trimmed the middle bit):
{
"http://example.com/comments": {
"comments": {
"data": [
...
],
"paging": {
"cursors": {
"after": "NDc4OQ==",
"before": "NDgyMg=="
},
"next": "https://graph.facebook.com/10150107083136229/comments?summary=1&limit=25&after=NDc4OQ\u00253D\u00253D"
},
"summary": {
"order": "ranked",
"total_count": 4822
}
}
}
}
In the "summary" section you can see there is a total_count which is the number of comments made on that URL.
So your process will be:
Loop through all the links you want to check
Hit the Facebook Graph API for that URL Extract the total_count response in the JSON and
store it (perhaps in a table)
Order the results on the number of comments descending, limiting to
only the first 5 results (if you're using MySQL then something like
SELECT * FROM whatever ORDER BY total_count DESC LIMIT 5)

Facebook: Get friended fans of page

basicly I want to rebuild the "You and this page" function. This question has been asked multiple times, but there was no working solution.
I'm trying to get a list of people who are the logged in users friends and like a specific page. I tried the following query with a user access token but got an empty result:
SELECT user_id FROM like WHERE object_id=91290503700 AND user_id IN (SELECT uid1 FROM friend WHERE uid2=THE_USERS_ID)&access_token=TOKEN
This query returns an empty result, although I have 20 friends who like Inception (91290503700). I know I can query all my friend's likes and check them against the page id, but for 450 friends it just needs a while, even with batch processing (for me it took 14-27 seconds for these nine batches).
Thx!
SELECT uid FROM page_fan WHERE page_id=PAGE_ID AND uid IN (SELECT uid1 FROM friend WHERE uid2=me())
This worked great for me with all permissions granted for my user token. Play around with the permissions to find what permissions you need for this FQL statement to work.
{
"data": [
{
"uid": 95193664134392
},
{
"uid": 91440825654091
},
{
"uid": 96905133509693
}
]
}

Facebook Graph API - get ID for a URL?

This seems like a pretty obvious, basic thing to expect from the Graph API, but I'm having serious difficulty with it. All I want to do is get the ID for any particular URL. They have a method for this:
https://graph.facebook.com/?ids=http://www.imdb.com/title/tt0117500/
And that works great. But if I try another URL, say for my blog,
https://graph.facebook.com/?ids=http://dusda.vox.com
it doesn't give me back a numerical ID like all of the examples do. Instead, this:
{"http:\/\/dusda.vox.com":{"id":"http:\/\/dusda.vox.com"}}
If I try to use that "id", I get jack (probably because the query string looks impossible to parse):
Request: https://graph.facebook.com/http://dusda.vox.com/likes
Response: {"id":"http:\/\/dusda.vox.com\/likes"}
So what's up with this? Is the Graph API just selectively reliable, or am I misunderstanding something? I've tried it on URLs that I know are popular on Facebook, too, and I've gotten mixed results.
Try FQL for this;
http://graph.facebook.com/fql?q=select%20url%2C%20id%2C%20type%2C%20site%20from%20object_url%20where%20url%20%3D%20%22http%3A%2F%2Fkriek.hu%2F%22
returns:
{
"data": [
{
"url": "http://kriek.hu/",
"id": 497425470154,
"type": "link",
"site": "kriek.hu"
}
]
}
For more information, see object_url.
I hope it helps!
The ID is given by Facebook only to pages which have a fbshare/like button. Else the API returns the number of shares and the request URL.
If I use the facebook object debugger page I can scrape every url, for example:
https://developers.facebook.com/tools/debug/og/object?q=ddnl.de
The page give me back an url with ID and so I can get every needed parameters.
In this case https://graph.facebook.com/10150164108649475
But I don't get this ID or url with FQL or otherwise?
Very old question, but here's what I found works for me as none of the answers here really resolved my issue:
If you have a custom object tied to a url, the method suggested by Pepe only gives the id FB assigns to the url where type=link. (Which is not tied to any comments)
In my case, I need my custom object id so that I could pull associated comments from it. You can get the object id using FQL by doing a select on 'comments_fbid' from the 'link_stat' table. (This will return the object id even if no comments have been added so it should work for other cases)
api.facebook.com
At this time no of the suggested solutions work for all urls. Only the Debugger is able to get the Graph ID correctly
For example
Debugger:
https://developers.facebook.com/tools/debug/og/object?q=http%3A%2F%2Fwww.amazon.de%2Fgp%2Fproduct%2F3810510793%2F
For URL:
www.amazon.de/gp/product/3442465583/
Result:
https://graph.facebook.com/10150771435736113
{
"url": "http://www.amazon.de/dp/3810510793/ref=tsm_1_fb_lk",
"type": "book",
"title": "Die unwahrscheinliche Pilgerreise des Harold Fry: Roman",
"image": [
{
"url": "http://ecx.images-amazon.com/images/I/51I4E81xrRL._SL160_.jpg"
}
],
"description": "Die unwahrscheinliche Pilgerreise des Harold Fry: Roman",
"site_name": "Amazon.de",
"updated_time": "2012-12-19T16:54:27+0000",
"id": "10150771435736113",
"application": {
"id": "164734381262",
"name": "Amazon",
"url": "https://www.facebook.com/apps/application.php?id=164734381262"
}
}
I had the same problem here, I was trying to get the same data IMDB gets. After almost bang my head against the wall, I decided to look at the facebook's js function. And look what I get, the explanation is on the link.
Getting limited data from a page which has a Facebook ID
Peace