get feed when some one tagged user in photo FQL - facebook

I want feed when some one tagged user in photo currently i am only able to get that photo but not feed with comments and likes as below
select object_id,src from photo where pid in (SELECT pid FROM photo_tag WHERE subject=me())
FYI currently i need to get first all photos then have to check whether it is photo of user himself or tagged by someone. so it seem lil bit complex..
thanks in advance

i sorted out finally...Through below FQL you can get with type=65
SELECT type,post_id, actor_id, message,comments,attachment,description,created_time,updated_time FROM stream WHERE source_id =me()

Related

How to Get Share count of a picture while it says share_count is not a member of photo table

I am using this query and trying to get share count of each pic but it returns an error.
SELECT link, comment_info, like_info, created, pid, src_big FROM photo WHERE aid
IN (SELECT aid FROM album WHERE owner=20531316728)ORDER BY share_count desc
I do want to order the last 20 pictures with there share count. Can somebody help me how could I achieve this.
I am not writing an application. Just testing it in Graph API explorer v2.0 API in developer tools.
This isn't possible because there exists no share_count field in the FQL photo table. https://developers.facebook.com/docs/reference/fql/photo/

Get all photos the user is tagged in on Facebook

I'm trying to fetch all the images I'm tagged in on Facebook.
It's working almost as it should, I just got one problem.
If I'm tagged in the post, but not tagged on the image, it doesn't show up in the output.
Any ideas why?
Here is my code:
SELECT pid, src_big, link, album_object_id, object_id, place_id, aid, created
FROM photo
WHERE pid IN (SELECT pid, object_id FROM photo_tag WHERE subject = me());
On-picture tags are not the same as tags in the description (post).
There are three FQL tables to get the content where a user has been tagged:
photo_tag to get tags on photos,
stream_tag to get tags on posts,
video_tag to get tags on videos.
You used the first one but you also need the second one. Similarly to your photo tags request, you will then have to use the stream table.

Using the Facebook Graphi API, how can I retrieve paginated photos in which my friends are tagged from a specific album?

I want to show the photos of an album in my app. Using the graph API i am able to filter and page by month, like below, which is great. I loop trough the results and get the photo for each id. Best of all, the GRAPH API also gives me a 'next' and 'previous' paging link. Very useful.
http://graph.facebook.com/[photo-album-id]/photos/?fields=id&limit=6&since=last month
But now i want to retrieve only those ids filter in two ways:
Only retrieve those in which the user is tagged
Only retrieve those in which the user & his/her friends are tagged.
I couldn't find any way to do this, with the graph API. Is there an alternative via FQL, that still has the paging in there?
Last alternative I can think of is program is in FQL, and do the paging myself.
p.s. I am doing this in Javascript currently.
You can retrieve photos the current user is tagged in in a specific album with this FQL call:
select object_id, src, album_object_id from photo where pid in (select pid from photo_tag where subject=me()) and and album_object_id=somenumber
To retrieve photos in which the user's friends are tagged, for a specific album:
select object_id, src, album_object_id from photo where pid in (select pid from photo_tag where subject in (select uid2 FROM friend WHERE uid1 = me())) and album_object_id=somenumber
As far as I know these results will not be paginated. For a detailed take on how to paginate fb queries see the Facebook Developer Blog: How-To: Paging with the Graph API and FQL
After a little play with the Graph Explorer (https://developers.facebook.com/tools/explorer/) I come up with this solution. You can make a call to Graph API as follows
/me?fields=friends.limit(5).fields(photos.limit(5))
The first limit is for how many friends you want to get and the second limit is how many photos you want from each friend.
At the end of the data there already is the next page URL.
I only tested on the explorer but should work.
Hope that helps,
Doruk

Fql, fetching "photos of me"

In my facebook page, when someone who's not the admin posts a photo, it goes into an album called "photos of me" that is different from other albums made by me.
It has no 'aid'... its url is:
http://www.facebook.com/photo.php?fbid=1760432628996&set=o.373236069382570&type=1&permPage=1
Photos are public, you can see them even if you're not registered on facebook.
I'm able to fetch photos in other albums of my page using this FQL:
SELECT pid, src, caption FROM photo WHERE aid = 'MY_ALBUM_ID' ORDER BY created DESC
But I can't fetch photos in "photos of me" album because there's not 'aid'. I tried to query the stream but I got only pictures I posted on my wall.
Could someone paste me the correct FQL to fetch photos on the album above?
These are photos you've been tagged in, so they aren't your photos. That's why they don't show up in any of your albums.
This query gets them:
SELECT pid, object_id, src, caption FROM photo WHERE object_id IN
(SELECT object_id FROM photo_tag WHERE subject='373236069382570')
According to the developer reference, FB prefers object_id to pid now. You might want to work with object_ids to prevent breaking your code if FB deprecates pid.

How to get total number of albums of all facebook friends?

How to get total number of albums of all facebook friends?
I want to retrieve all facebook friends total albums in one go.
Anyone have have idea how to query "album" table in FB
plz share ur thoughts thanks
I've came across this link earlier today, sound similar to your question
FQL for returning all album names and object id's of the albums for ALL friends of a user
If you removed the "LIMIT 25" as ifaour mentioned from his example side note, the query would look like this and do the task
SELECT aid, owner, name FROM album WHERE owner IN (SELECT uid2 FROM friend WHERE uid1=me())
2nd step: let's put it into a multi-query format
{"query1":"SELECT aid, owner, name FROM album WHERE owner IN (SELECT uid2 FROM friend WHERE uid1=me())","query2":"SELECT owner, album_object_id, object_id FROM photo WHERE aid IN (SELECT aid FROM #query1)"}
I guess you'll need to modify the fields in query2 to fit it into your scenario
These will return as 2 big fat json objects with 5000 results limit... which I haven't figured out a solution to query the next 5000 and the rest...
Also, I think there's a bug in both FQL and Graph API, some of my friends' albums are NOT showing in the result... (yes, with the right permission and necessary scopes to browse and query...) I've fired a bug report for this issue