Profile.getFBML

From Facebook Developer Wiki

Jump to: navigation, search

Contents

Description

Facebook will deprecate this method in late 2009/early 2010.

To integrate into the profile, use application tabs. For more information, please read the Developer Roadmap.

Gets the FBML for the profile box that is currently set for a user's profile (your application set the FBML previously by calling the profile.setFBML method). See the FBML documentation for a description of the markup and its role in various contexts.

It is not a violation of Facebook Privacy policy if you use this method to retrieve content originally rendered by your application from a user's profile, even if Facebook privacy restrictions would otherwise keep you from seeing that user’s profile (for example, you are not friends with the user in question). Cases where this would arise include verifying content posted by one user of your application to another user’s profile complies with the Facebook Developer Terms of Service.

For Web applications, you must pass either the ID of the user on whose behalf you're making this call or the session key for that user, but not both. If you don't specify a user with the uid parameter, then that user whose session it is will be the target of the call.

However, if your application is a desktop application, you must pass a valid session key for security reasons. Do not pass a uid parameter.

There are two separate forms of profile boxes: the narrow and wide column profile boxes for the Boxes tab, and the main profile boxes (which appear only on the Wall and Info tabs). Specify the type to distinguish between the two. For backwards compatibility, it defaults to the original style.

Parameters

RequiredNameTypeDescription
required api_key string The application key associated with the calling application. If you specify the API key in your client, you don't need to pass it with every call.
call_id float The request's sequence number. Each successive call for any session must use a sequence number greater than the last. We suggest using the current time in milliseconds, such as PHP's microtime(true) function. If you specify the call ID in your client, you don't need to pass it with every call.
sig string An MD5 hash of the current request and your secret key, as described in the How Facebook Authenticates Your Application. Facebook computes the signature for you automatically.
v string This must be set to 1.0 to use this version of the API. If you specify the version in your client, you don't need to pass it with every call.
optional session_key string The session key of the user whose FBML you are retrieving.
Note: A session key is always required for desktop applications. It is required for Web applications only when the uid is not specified.
format string The desired response format, which can be either XML or JSON. (Default value is XML.)
callback string Name of a function to call. This is primarily to enable cross-domain JavaScript requests using the <script> tag, sometimes known as "JSONP". This works with both XML and JSON.
uid int The user whose profile FBML is to be fetched, or the page ID in case of a Page. If not specified, defaults to the session user.
Note: This parameter applies only to Web applications and is required by them only if the session_key is not specified. Facebook ignores this parameter if it is passed by a desktop application.
type int The type of profile box to retrieve. Specify 1 for wide and narrow column boxes for the Boxes tab), 2 for profile_main box for the user's Wall and Info tabs. (Default value is 1.)

Example Return XML

<?xml version="1.0" encoding="UTF-8"?> <profile_getFBML_response xmlns="http://api.facebook.com/1.0/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://api.facebook.com/1.0/ http://api.facebook.com/1.0/facebook.xsd"> <fb:if-is-own-profile>MyAAA profile! <fb:else> NotAAA my profile!</fb:else> </fb:if-is-own-profile> </profile_getFBML_response>

Error Codes

CodeDescription
1 An unknown error occurred. Please resubmit the request.
2 The service is not available at this time.
4 The application has reached the maximum number of requests allowed. More requests are allowed once the time window has completed.
5 The request came from a remote address not allowed by this application.
100 One of the parameters specified was missing or invalid.
101 The API key submitted is not associated with any known application.
102 The session key was improperly submitted or has reached its timeout. Direct the user to log in again to obtain another key.
103 The submitted call_id was not greater than the previous call_id for this session.
104 Incorrect signature.

Notes

  • This function does not require a session_key, unless it is being called by a desktop application.