THIS CLASS SHOULD BE CONSIDERED DEPRECATED.
All public members of this class are intentionally deprecated. New code should instead use Session to manage session state, Request to make API requests, and WebDialog to make dialog requests.
Adding @Deprecated to this class causes warnings in other deprecated classes that reference this one. That is the only reason this entire class is not deprecated.
Extends: | Object |
Package: | android |
Facebook(String)
Constructor for Facebook object.
public Facebook(String appId)
Parameter | Description |
---|---|
appId | Your Facebook application ID. Found at www.facebook.com/developers/apps.php. |
getAttributionId(ContentResolver)
Get Attribution ID for app install conversion tracking.
This method is deprecated. See Facebook and Settings for more info.
public static String getAttributionId(ContentResolver contentResolver)
Parameter | Description |
---|---|
contentResolver |
authorize(Activity, DialogListener)
Default authorize method. Grants only basic permissions.
See authorize() below for @params.
This method is deprecated. See Facebook and Session for more info.
public void authorize(Activity activity, DialogListener listener)
Parameter | Description |
---|---|
activity | |
listener |
authorize(Activity, String, DialogListener)
Authorize method that grants custom permissions.
See authorize() below for @params.
This method is deprecated. See Facebook and Session for more info.
public void authorize(Activity activity, String permissions, DialogListener listener)
Parameter | Description |
---|---|
activity | |
permissions | |
listener |
authorize(Activity, String, int, DialogListener)
Full authorize method.
Starts either an Activity or a dialog which prompts the user to log in to Facebook and grant the requested permissions to the given application.
This method will, when possible, use Facebook's single sign-on for Android to obtain an access token. This involves proxying a call through the Facebook for Android stand-alone application, which will handle the authentication flow, and return an OAuth access token for making API calls.
Because this process will not be available for all users, if single sign-on is not possible, this method will automatically fall back to the OAuth 2.0 User-Agent flow. In this flow, the user credentials are handled by Facebook in an embedded WebView, not by the client application. As such, the dialog makes a network request and renders HTML content rather than a native UI. The access token is retrieved from a redirect to a special URL that the WebView handles.
Note that User credentials could be handled natively using the OAuth 2.0 Username and Password Flow, but this is not supported by this SDK.
See http://developers.facebook.com/docs/authentication/ and http://wiki.oauth.net/OAuth-2 for more details.
Note that this method is asynchronous and the callback will be invoked in the original calling thread (not in a background thread).
Also note that requests may be made to the API without calling authorize first, in which case only public information is returned.
IMPORTANT: Note that single sign-on authentication will not function correctly if you do not include a call to the authorizeCallback() method in your onActivityResult() function! Please see below for more information. single sign-on may be disabled by passing FORCE_DIALOG_AUTH as the activityCode parameter in your call to authorize().
This method is deprecated. See Facebook and Session for more info.
public void authorize(Activity activity, String permissions, int activityCode, DialogListener listener)
Parameter | Description |
---|---|
activity | The Android activity in which we want to display the authorization dialog. |
permissions | A list of permissions required for this application: e.g. "read_stream", "publish_stream", "offline_access", etc. see http://developers.facebook.com/docs/authentication/permissions This parameter should not be null -- if you do not require any permissions, then pass in an empty String array. |
activityCode | Single sign-on requires an activity result to be called back to the client application -- if you are waiting on other activities to return data, pass a custom activity code here to avoid collisions. If you would like to force the use of legacy dialog-based authorization, pass FORCE_DIALOG_AUTH for this parameter. Otherwise just omit this parameter and Facebook will use a suitable default. See http://developer.android.com/reference/android/ app/Activity.html for more information. |
listener | Callback interface for notifying the calling application when the authentication dialog has completed, failed, or been canceled. |
authorizeCallback(int, int, Intent)
IMPORTANT: If you are using the deprecated authorize() method, this method must be invoked at the top of the calling activity's onActivityResult() function or Facebook authentication will not function properly!
If your calling activity does not currently implement onActivityResult(), you must implement it and include a call to this method if you intend to use the authorize() method in this SDK.
For more information, see http://developer.android.com/reference/android/app/ Activity.html#onActivityResult(int, int, android.content.Intent)
This method is deprecated. See Facebook and Session for more info.
public void authorizeCallback(int requestCode, int resultCode, Intent data)
Parameter | Description |
---|---|
requestCode | |
resultCode | |
data |
extendAccessToken(Context, ServiceListener)
Refresh OAuth access token method. Binds to Facebook for Android stand-alone application application to refresh the access token. This method tries to connect to the Facebook App which will handle the authentication flow, and return a new OAuth access token. This method will automatically replace the old token with a new one. Note that this method is asynchronous and the callback will be invoked in the original calling thread (not in a background thread).
This method is deprecated. See Facebook and Session for more info.
public boolean extendAccessToken(Context context, ServiceListener serviceListener)
Parameter | Description |
---|---|
context | The Android Context that will be used to bind to the Facebook RefreshToken Service |
serviceListener | Callback interface for notifying the calling application when the refresh request has completed or failed (can be null). In case of a success a new token can be found inside the result Bundle under Facebook.ACCESS_TOKEN key. |
extendAccessTokenIfNeeded(Context, ServiceListener)
Calls extendAccessToken if shouldExtendAccessToken returns true.
This method is deprecated. See Facebook and Session for more info.
public boolean extendAccessTokenIfNeeded(Context context, ServiceListener serviceListener)
Parameter | Description |
---|---|
context | |
serviceListener |
shouldExtendAccessToken()
Check if the access token requires refreshing.
This method is deprecated. See Facebook and Session for more info.
public boolean shouldExtendAccessToken()
logout(Context)
Invalidate the current user session by removing the access token in memory, clearing the browser cookie, and calling auth.expireSession through the API.
Note that this method blocks waiting for a network response, so do not call it in a UI thread.
This method is deprecated. See Facebook and Session for more info.
public String logout(Context context)
Parameter | Description |
---|---|
context | The Android context in which the logout should be called: it should be the same context in which the login occurred in order to clear any stored cookies |
request(Bundle)
Make a request to Facebook's old (pre-graph) API with the given parameters. One of the parameter keys must be "method" and its value should be a valid REST server API method.
See http://developers.facebook.com/docs/reference/rest/
Note that this method blocks waiting for a network response, so do not call it in a UI thread.
Example: Bundle parameters = new Bundle(); parameters.putString("method", "auth.expireSession"); String response = request(parameters);
This method is deprecated. See Facebook and Request for more info.
public String request(Bundle parameters)
Parameter | Description |
---|---|
parameters | Key-value pairs of parameters to the request. Refer to the documentation: one of the parameters must be "method". |
request(String)
Make a request to the Facebook Graph API without any parameters.
See http://developers.facebook.com/docs/api
Note that this method blocks waiting for a network response, so do not call it in a UI thread.
This method is deprecated. See Facebook and Request for more info.
public String request(String graphPath)
Parameter | Description |
---|---|
graphPath | Path to resource in the Facebook graph, e.g., to fetch data about the currently logged authenticated user, provide "me", which will fetch http://graph.facebook.com/me |
request(String, Bundle)
Make a request to the Facebook Graph API with the given string parameters using an HTTP GET (default method).
See http://developers.facebook.com/docs/api
Note that this method blocks waiting for a network response, so do not call it in a UI thread.
This method is deprecated. See Facebook and Request for more info.
public String request(String graphPath, Bundle parameters)
Parameter | Description |
---|---|
graphPath | Path to resource in the Facebook graph, e.g., to fetch data about the currently logged authenticated user, provide "me", which will fetch http://graph.facebook.com/me |
parameters | Key-value string parameters, e.g. the path "search" with parameters "q" : "facebook" would produce a query for the following graph resource: https://graph.facebook.com/search?q=facebook |
request(String, Bundle, String)
Synchronously make a request to the Facebook Graph API with the given HTTP method and string parameters. Note that binary data parameters (e.g. pictures) are not yet supported by this helper function.
See http://developers.facebook.com/docs/api
Note that this method blocks waiting for a network response, so do not call it in a UI thread.
This method is deprecated. See Facebook and Request for more info.
public String request(String graphPath, Bundle params, String httpMethod)
Parameter | Description |
---|---|
graphPath | Path to resource in the Facebook graph, e.g., to fetch data about the currently logged authenticated user, provide "me", which will fetch http://graph.facebook.com/me |
params | Key-value string parameters, e.g. the path "search" with parameters {"q" : "facebook"} would produce a query for the following graph resource: https://graph.facebook.com/search?q=facebook |
httpMethod | Http verb, e.g. "GET", "POST", "DELETE" |
dialog(Context, String, DialogListener)
Generate a UI dialog for the request action in the given Android context.
Note that this method is asynchronous and the callback will be invoked in the original calling thread (not in a background thread).
This method is deprecated. See WebDialog.
public void dialog(Context context, String action, DialogListener listener)
Parameter | Description |
---|---|
context | The Android context in which we will generate this dialog. |
action | String representation of the desired method: e.g. "login", "stream.publish", ... |
listener | Callback interface to notify the application when the dialog has completed. |
dialog(Context, String, Bundle, DialogListener)
Generate a UI dialog for the request action in the given Android context with the provided parameters.
Note that this method is asynchronous and the callback will be invoked in the original calling thread (not in a background thread).
This method is deprecated. See WebDialog.
public void dialog(Context context, String action, Bundle parameters, DialogListener listener)
Parameter | Description |
---|---|
context | The Android context in which we will generate this dialog. |
action | String representation of the desired method: e.g. "feed" ... |
parameters | String key-value pairs to be passed as URL parameters. |
listener | Callback interface to notify the application when the dialog has completed. |
isSessionValid()
Returns whether the current access token is valid
public boolean isSessionValid()
setSession(Session)
Allows the user to set a Session for the Facebook class to use. If a Session is set here, then one should not use the authorize, logout, or extendAccessToken methods which alter the Session object since that may result in undefined behavior. Using those methods after setting the session here will result in exceptions being thrown.
public void setSession(Session session)
Parameter | Description |
---|---|
session | The Session object to use, cannot be null |
getSession()
Get the underlying Session object to use with 3.0 api.
public final Session getSession()
getAccessToken()
Retrieve the OAuth 2.0 access token for API access: treat with care. Returns null if no session exists.
public String getAccessToken()
getAccessExpires()
Retrieve the current session's expiration time (in milliseconds since Unix epoch), or 0 if the session doesn't expire or doesn't exist.
public long getAccessExpires()
getLastAccessUpdate()
Retrieve the last time the token was updated (in milliseconds since the Unix epoch), or 0 if the token has not been set.
public long getLastAccessUpdate()
setTokenFromCache(String, long, long)
Restore the token, expiration time, and last update time from cached values. These should be values obtained from getAccessToken(), getAccessExpires, and getLastAccessUpdate() respectively.
This method is deprecated. See Facebook and Session for more info.
public void setTokenFromCache(String accessToken, long accessExpires, long lastAccessUpdate)
Parameter | Description |
---|---|
accessToken | - access token |
accessExpires | - access token expiration time |
lastAccessUpdate | - timestamp of the last token update |
setAccessToken(String)
Set the OAuth 2.0 access token for API access.
This method is deprecated. See Facebook and Session for more info.
public void setAccessToken(String token)
Parameter | Description |
---|---|
token | - access token |
setAccessExpires(long)
Set the current session's expiration time (in milliseconds since Unix epoch), or 0 if the session doesn't expire.
This method is deprecated. See Facebook and Session for more info.
public void setAccessExpires(long timestampInMsec)
Parameter | Description |
---|---|
timestampInMsec | - timestamp in milliseconds |
setAccessExpiresIn(String)
Set the current session's duration (in seconds since Unix epoch), or "0" if session doesn't expire.
This method is deprecated. See Facebook and Session for more info.
public void setAccessExpiresIn(String expiresInSecsFromNow)
Parameter | Description |
---|---|
expiresInSecsFromNow | - duration in seconds (or 0 if the session doesn't expire) |
getAppId()
This method is deprecated. See Facebook and Session for more info.
public String getAppId()
setAppId(String)
This method is deprecated. See Facebook and Session for more info.
public void setAppId(String appId)
Parameter | Description |
---|---|
appId | The String representing the application ID |
getShouldAutoPublishInstall()
Get the auto install publish setting. If true, an install event will be published during authorize(), unless it has occurred previously or the app does not have install attribution enabled on the application's developer config page.
This method is deprecated. See Facebook and Settings for more info.
public boolean getShouldAutoPublishInstall()
setShouldAutoPublishInstall(boolean)
Sets whether auto publishing of installs will occur.
This method is deprecated. See Facebook and Settings for more info.
public void setShouldAutoPublishInstall(boolean value)
Parameter | Description |
---|---|
value | A Boolean indicating whether installation of the app should be auto-published. |
REDIRECT_URI
public static final String REDIRECT_URI
CANCEL_URI
public static final String CANCEL_URI
TOKEN
public static final String TOKEN
EXPIRES
public static final String EXPIRES
SINGLE_SIGN_ON_DISABLED
public static final String SINGLE_SIGN_ON_DISABLED
ATTRIBUTION_ID_CONTENT_URI
public static final Uri ATTRIBUTION_ID_CONTENT_URI
ATTRIBUTION_ID_COLUMN_NAME
public static final String ATTRIBUTION_ID_COLUMN_NAME
FORCE_DIALOG_AUTH
public static final int FORCE_DIALOG_AUTH
FB_APP_SIGNATURE
public static final String FB_APP_SIGNATURE