FBSDKLoginManager
provides methods for logging the user in and out.
FBSDKLoginManager
works directly with [FBSDKAccessToken currentAccessToken]
and
sets the "currentAccessToken" upon successful authorizations (or sets nil
in case of logOut
).
You should check [FBSDKAccessToken currentAccessToken]
before calling logIn* to see if there is
a cached token available (typically in your viewDidLoad).
If you are managing your own token instances outside of "currentAccessToken", you will need to set
"currentAccessToken" before calling logIn* to authorize further permissions on your tokens.
Superclass: | NSObject |
Declared in: | FBSDKLoginManager.h |
defaultAudience
The default audience.
@property (assign,
nonatomic) FBSDKDefaultAudience defaultAudience;
You should set this if you intend to ask for publish permissions.
FBSDKLoginManager.h
loginBehavior
The login behavior
@property (assign,
nonatomic) FBSDKLoginBehavior loginBehavior;
FBSDKLoginManager.h
renewSystemCredentials:
Issues an asynchronous renewCredentialsForAccount call to the device's Facebook account store.
Parameter | Description |
---|---|
handler | The completion handler to call when the renewal is completed. This can be invoked on an arbitrary thread. |
+ (void)
renewSystemCredentials | |
void | |
^ | |
ACAccountCredentialRenewResult | |
result | |
NSError | |
error | |
handler; |
This can be used to explicitly renew account credentials and is provided as a convenience wrapper around
[ACAccountStore renewCredentialsForAccount:completion]
. Note the method will not issue the renewal call if the the
Facebook account has not been set on the device, or if access had not been granted to the account (though the handler
wil receive an error).
If the [FBSDKAccessToken currentAccessToken]
was from the account store, a succesful renewal will also set
a new "currentAccessToken".
FBSDKLoginManager.h
logInWithPublishPermissions:fromViewController:handler:
Logs the user in or authorizes additional permissions.
Parameter | Description |
---|---|
permissions | The optional array of permissions. Note this is converted to NSSet and is only an NSArray for the convenience of literal syntax. |
fromViewController | The view controller to present from. If nil, the topmost view controller will be automatically determined as best as possible. |
handler | The callback. |
- (void)
logInWithPublishPermissions: | (NSArray *)permissions |
fromViewController: | (UIViewController *)fromViewController |
handler: | (FBSDKLoginManagerRequestTokenHandler)handler; |
Use this method when asking for publish permissions. You should only ask for permissions when they
are needed and explain the value to the user. You can inspect the result.declinedPermissions to also
provide more information to the user if they decline permissions.
This method will present UI the user. You typically should check if [FBSDKAccessToken currentAccessToken]
already contains the permissions you need before asking to reduce unnecessary app switching. For example,
you could make that check at viewDidLoad.
FBSDKLoginManager.h
logInWithPublishPermissions:handler:
- (void)
logInWithPublishPermissions: | (NSArray *)permissions |
handler: | (FBSDKLoginManagerRequestTokenHandler)handler |
__attribute__((deprecated("use logInWithPublishPermissions:fromViewController:handler: instead")));
FBSDKLoginManager.h
logInWithReadPermissions:fromViewController:handler:
Logs the user in or authorizes additional permissions.
Parameter | Description |
---|---|
permissions | The optional array of permissions. Note this is converted to NSSet and is only an NSArray for the convenience of literal syntax. |
fromViewController | The view controller to present from. If nil, the topmost view controller will be automatically determined as best as possible. |
handler | The callback. |
- (void)
logInWithReadPermissions: | (NSArray *)permissions |
fromViewController: | (UIViewController *)fromViewController |
handler: | (FBSDKLoginManagerRequestTokenHandler)handler; |
Use this method when asking for read permissions. You should only ask for permissions when they
are needed and explain the value to the user. You can inspect the result.declinedPermissions to also
provide more information to the user if they decline permissions.
This method will present UI the user. You typically should check if [FBSDKAccessToken currentAccessToken]
already contains the permissions you need before asking to reduce unnecessary app switching. For example,
you could make that check at viewDidLoad.
FBSDKLoginManager.h
logInWithReadPermissions:handler:
- (void)
logInWithReadPermissions: | (NSArray *)permissions |
handler: | (FBSDKLoginManagerRequestTokenHandler)handler |
__attribute__((deprecated("use logInWithReadPermissions:fromViewController:handler: instead")));
FBSDKLoginManager.h
logOut
Logs the user out
- (void)
logOut;
This calls [FBSDKAccessToken setCurrentAccessToken:nil] and [FBSDKProfile setCurrentProfile:nil].
FBSDKLoginManager.h
FBSDKDefaultAudience enum
Passed to open to indicate which default audience to use for sessions that post data to Facebook.
typedef NS_ENUM(NSUInteger, FBSDKDefaultAudience) { /*! Indicates that the user's friends are able to see posts made by the application */ FBSDKDefaultAudienceFriends = 0, /*! Indicates that only the user is able to see posts made by the application */ FBSDKDefaultAudienceOnlyMe, /*! Indicates that all Facebook users are able to see posts made by the application */ FBSDKDefaultAudienceEveryone, };
Constant | Description |
---|---|
FBSDKDefaultAudienceFriends | Indicates that the user's friends are able to see posts made by the application |
FBSDKDefaultAudienceOnlyMe | Indicates that only the user is able to see posts made by the application |
FBSDKDefaultAudienceEveryone | Indicates that all Facebook users are able to see posts made by the application |
Certain operations such as publishing a status or publishing a photo require an audience. When the user grants an application permission to perform a publish operation, a default audience is selected as the publication ceiling for the application. This enumerated value allows the application to select which audience to ask the user to grant publish permission for.
FBSDKLoginManager.h
FBSDKLoginBehavior enum
Attempts log in through a modal \c UIWebView pop up This behavior is only available to certain types of apps. Please check the Facebook Platform Policy to verify your app meets the restrictions.
typedef NS_ENUM(NSUInteger, FBSDKLoginBehavior) { /*! */ FBSDKLoginBehaviorNative = 0, /*! */ FBSDKLoginBehaviorBrowser, /*! */ FBSDKLoginBehaviorSystemAccount, /*! */ FBSDKLoginBehaviorWeb, };
Facebook Login authorizes the application to act on behalf of the user, using the user's Facebook account. Usually a Facebook Login will rely on an account maintained outside of the application, by the native Facebook application, the browser, or perhaps the device itself. This avoids the need for a user to enter their username and password directly, and provides the most secure and lowest friction way for a user to authorize the application to interact with Facebook. The \c FBSDKLoginBehavior enum specifies which log-in methods may be used. The SDK will determine the best behavior based on the current device (such as iOS version).
FBSDKLoginManager.h
FBSDKLoginManagerRequestTokenHandler
Describes the call back to the FBSDKLoginManager
typedef void (^FBSDKLoginManagerRequestTokenHandler)( FBSDKLoginManagerLoginResult *result, NSError *error);
FBSDKLoginManager.h
NS_ENUM
Passed to open to indicate which default audience to use for sessions that post data to Facebook.
typedef NS_ENUM(NSUInteger, FBSDKDefaultAudience) { /*! Indicates that the user's friends are able to see posts made by the application */ FBSDKDefaultAudienceFriends = 0, /*! Indicates that only the user is able to see posts made by the application */ FBSDKDefaultAudienceOnlyMe, /*! Indicates that all Facebook users are able to see posts made by the application */ FBSDKDefaultAudienceEveryone, };
Constant | Description |
---|---|
FBSDKDefaultAudienceFriends | Indicates that the user's friends are able to see posts made by the application |
Certain operations such as publishing a status or publishing a photo require an audience. When the user grants an application permission to perform a publish operation, a default audience is selected as the publication ceiling for the application. This enumerated value allows the application to select which audience to ask the user to grant publish permission for.
FBSDKLoginManager.h
NS_ENUM
Attempts log in through a modal \c UIWebView pop up This behavior is only available to certain types of apps. Please check the Facebook Platform Policy to verify your app meets the restrictions.
typedef NS_ENUM(NSUInteger, FBSDKLoginBehavior) { /*! */ FBSDKLoginBehaviorNative = 0, /*! */ FBSDKLoginBehaviorBrowser, /*! */ FBSDKLoginBehaviorSystemAccount, /*! */ FBSDKLoginBehaviorWeb, };
Facebook Login authorizes the application to act on behalf of the user, using the user's Facebook account. Usually a Facebook Login will rely on an account maintained outside of the application, by the native Facebook application, the browser, or perhaps the device itself. This avoids the need for a user to enter their username and password directly, and provides the most secure and lowest friction way for a user to authorize the application to interact with Facebook. The \c FBSDKLoginBehavior enum specifies which log-in methods may be used. The SDK will determine the best behavior based on the current device (such as iOS version).
FBSDKLoginManager.h