This repository has been archived by the owner on Apr 2, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 910
/
FBLoginManager.js
121 lines (113 loc) · 3.88 KB
/
FBLoginManager.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/**
* Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
*
* You are hereby granted a non-exclusive, worldwide, royalty-free license to use,
* copy, modify, and distribute this software in source code or binary form for use
* in connection with the web services and APIs provided by Facebook.
*
* As with any software that integrates with the Facebook platform, your use of
* this software is subject to the Facebook Developer Principles and Policies
* [http://developers.facebook.com/policy/]. This copyright notice shall be
* included in all copies or substantial portions of the software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
* @flow
* @format
*/
'use strict';
const LoginManager = require('react-native').NativeModules.FBLoginManager;
/**
* Indicates which default audience to use for sessions that post data to Facebook.
*/
export type DefaultAudience =
// Indicates that the user's friends are able to see posts made by the application.
| 'friends'
// Indicates that all Facebook users are able to see posts made by the application.
| 'everyone'
// Indicates that only the user is able to see posts made by the application.
| 'only_me';
export type LoginBehavior = LoginBehaviorIOS | LoginBehaviorAndroid;
/**
* Indicate how Facebook Login should be attempted on Android.
*/
export type LoginBehaviorAndroid =
// Attempt login in using the Facebook App, and if that does not work fall back to web dialog auth.
| 'native_with_fallback'
// Only attempt to login using the Facebook App.
| 'native_only'
// Only the web dialog auth should be used.
| 'web_only';
/**
* Indicate how Facebook Login should be attempted on iOS.
*/
export type LoginBehaviorIOS =
// Attempts log in through the native Facebook app.
// The SDK may still use Safari instead.
// See details in https://developers.facebook.com/blog/post/2015/10/29/Facebook-Login-iOS9/
| 'native'
// Attempts log in through the Safari browser.
| 'browser'
// Attempts log in through the Facebook account currently signed in through Settings.
| 'system_account'
// Attempts log in through a modal UIWebView pop-up.
| 'web';
/**
* Shows the results of a login operation.
*/
export type LoginResult = {
isCancelled: boolean,
grantedPermissions?: Array<string>,
declinedPermissions?: Array<string>,
};
module.exports = {
/**
* Logs the user in with the requested read permissions.
*/
logInWithReadPermissions(permissions: Array<string>): Promise<LoginResult> {
return LoginManager.logInWithReadPermissions(permissions);
},
/**
* Logs the user in with the requested publish permissions.
*/
logInWithPublishPermissions(
permissions: Array<string>,
): Promise<LoginResult> {
return LoginManager.logInWithPublishPermissions(permissions);
},
/**
* Getter for the login behavior.
*/
getLoginBehavior(): Promise<LoginBehavior> {
return LoginManager.getLoginBehavior();
},
/**
* Setter for the login behavior.
*/
setLoginBehavior(loginBehavior: LoginBehavior) {
LoginManager.setLoginBehavior(loginBehavior);
},
/**
* Getter for the default audience.
*/
getDefaultAudience(): Promise<DefaultAudience> {
return LoginManager.getDefaultAudience();
},
/**
* Setter for the default audience.
*/
setDefaultAudience(defaultAudience: DefaultAudience) {
LoginManager.setDefaultAudience(defaultAudience);
},
/**
* Logs out the user.
*/
logOut() {
LoginManager.logOut();
},
};