Closed Klabauterman closed 3 years ago
Hi @Klabauterman Have you added the flutter_facebook_auth.js file in your web folder?.
Please check the example folder.
Also please add the complete index.html
Thanks for the quick response, I indeed forgot to add the flutter_facebook_auth.js file. Now it works!
Hello @Klabauterman and @darwin-morocho from where have you found flutter_facebook_auth.js file?
flutter_facebook_auth.js file
Hi @Abhishek01039 since flutter_facebook_auth: ^3.3.2
the flutter_facebook_auth.js
file is not need it any more because this plugin now uses the allowInterop
method to handle the facebook javascript SDK responses. Now you need to initialize the web sdk in your main function.
void main() {
// check if is running on Web
if (kIsWeb) {
// initialiaze the facebook javascript SDK
FacebookAuth.instance.webInitialize(
appId: "1329834907365798",//<-- YOUR APP_ID
cookie: true,
xfbml: true,
version: "v9.0",
);
}
runApp(MyApp());
}
For more info go to https://facebook.meedu.app/#/web
Also you can download a previous version of this plugin https://github.com/darwin-morocho/flutter-facebook-auth/releases/tag/v2.0.1 and go to the example/web
folder and find the flutter_facebook_auth.js
file
Yeah great, Thanks, @darwin-morocho for your help and now it is working fine. how we should handle the exception while login with Facebook?
switch (e.errorCode) {
case FacebookAuthErrorCode.OPERATION_IN_PROGRESS:
throw Exception(Message.previousLoginOperation);
case FacebookAuthErrorCode.CANCELLED:
throw Exception(Message.loginCancel);
case FacebookAuthErrorCode.FAILED:
throw Exception(Message.loginFailed);
default:
throw Exception(Message.genericLoginErrorMessage);
}
we have this in previous versions.
Yeah great, Thanks, @darwin-morocho for your help and now it is working fine. how we should handle the exception while login with Facebook?
switch (e.errorCode) { case FacebookAuthErrorCode.OPERATION_IN_PROGRESS: throw Exception(Message.previousLoginOperation); case FacebookAuthErrorCode.CANCELLED: throw Exception(Message.loginCancel); case FacebookAuthErrorCode.FAILED: throw Exception(Message.loginFailed); default: throw Exception(Message.genericLoginErrorMessage); }
we have this in previous versions.
You need to use
final LoginResult result = await FacebookAuth.instance.login();
if (result.status == LoginStatus.success) {
final accessToken = result.accessToken;
} else {
print(result.status);
print(result.message);
}
I am trying this.
I am trying this.
https://facebook.meedu.app/#/migration-guide
The FacebookAuthException class was removed and you don't need use any more a try and catch
Thanks @darwin-morocho Thanks again for your quick response.
I am trying this.
https://facebook.meedu.app/#/migration-guide
The FacebookAuthException class was removed and you don't need use any more a try and catch
Just use
if (result.status == LoginStatus.success) {
_accessToken = result.accessToken;
_printCredentials();
// get the user data
// by default we get the userId, email,name and picture
final userData = await FacebookAuth.instance.getUserData();
// final userData = await FacebookAuth.instance.getUserData(fields: "email,birthday,friends,gender,link");
_userData = userData;
} else if(result.status == LoginStatus.failed) {
print(result.message);
}else if(result.status == LoginStatus.cancelled) {
print(result.message);
}
Thanks 😊
Hello @darwin-morocho
what URL should I put here? I am just trying locally now. And Any other configuration needed for our flutter web app? because I am getting this error
The method FB.login can no longer be called from http pages. https://developers.facebook.com/blog/post/2018/06/08/enforce-https-facebook-login/
Hello @darwin-morocho
what URL should I put here? I am just trying locally now. And Any other configuration needed for our flutter web app? because I am getting this errro
The method FB.login can no longer be called from http pages. https://developers.facebook.com/blog/post/2018/06/08/enforce-https-facebook-login/
In your localhost you can test the login flow with some warnings because the javascript Facebook sdk only allows https connections
In localhost you can't use the FacebookAuth.instance.accessToken because it requires an oauth redirect URL that must be a valid site url with https, the URL should be the URL of your login page
can I add https://www.bearpeak.io into site URL which is there in facebook console?
can I add https://www.bearpeak.io into site URL which is there in facebook console
yes but that url must implements the Facebook login
Describe the bug Getting this stacktrace on startup of my webapp, although the following script was added to the index.html
TypeError: dart.global.FacebookAuth is not a constructor at new auth.Auth.new (http://localhost:7357/packages/flutter_facebook_auth_web/src/interop/auth.dart.lib.js:177:40) at new facebook_auth_plugin.FlutterFacebookAuthPlugin.new (http://localhost:7357/packages/flutter_facebook_auth_web/src/facebook_auth_plugin.dart.lib.js:94:44) at Function.registerWith (http://localhost:7357/packages/flutter_facebook_auth_web/src/facebook_auth_plugin.dart.lib.js:46:80) at Object.registerPlugins (http://localhost:7357/packages/koerbchen/generated_plugin_registrant.dart.lib.js:45:52) at main (http://localhost:7357/web_entrypoint.dart.lib.js:44:35) at main.next ()
at runBody (http://localhost:7357/dart_sdk.js:39052:34)
at Object._async [as async] (http://localhost:7357/dart_sdk.js:39083:7)
at main$ (http://localhost:7357/web_entrypoint.dart.lib.js:43:18)
at http://localhost:7357/main_module.bootstrap.js:19:10
at Array.forEach ()
at window.$dartRunMain (http://localhost:7357/main_module.bootstrap.js:18:32)
at :1:8
at Object.runMain (http://localhost:7357/dwds/src/injected/client.js:8656:21)
at http://localhost:7357/dwds/src/injected/client.js:22068:19
at _wrapJsFunctionForAsync_closure.$protected (http://localhost:7357/dwds/src/injected/client.js:3830:15)
at _wrapJsFunctionForAsync_closure.call$2 (http://localhost:7357/dwds/src/injected/client.js:10905:12)
at Object._asyncStartSync (http://localhost:7357/dwds/src/injected/client.js:3794:20)
at mainclosure1.$call$body$mainclosure (http://localhost:7357/dwds/src/injected/client.js:22080:16)
at mainclosure1.call$1 (http://localhost:7357/dwds/src/injected/client.js:22007:19)
at StaticClosure._rootRunUnary [as call$2$5] (http://localhost:7357/dwds/src/injected/client.js:4153:16)
at _CustomZone.runUnary$2$2 (http://localhost:7357/dwds/src/injected/client.js:12136:39)
at _CustomZone.runUnaryGuarded$1$2 (http://localhost:7357/dwds/src/injected/client.js:12068:14)
at _ControllerSubscription._sendData$1 (http://localhost:7357/dwds/src/injected/client.js:11697:19)
at _DelayedData.perform$1 (http://localhost:7357/dwds/src/injected/client.js:11849:59)
at _PendingEvents_schedule_closure.call$0 (http://localhost:7357/dwds/src/injected/client.js:11898:14)
at Object._microtaskLoop (http://localhost:7357/dwds/src/injected/client.js:3990:24)
at StaticClosure._startMicrotaskLoop (http://localhost:7357/dwds/src/injected/client.js:3996:11)
at _AsyncRuninitializeScheduleImmediate_internalCallback.call$1 (http://localhost:7357/dwds/src/injected/client.js:10774:9)
at invokeClosure (http://localhost:7357/dwds/src/injected/client.js:1250:26)
at MutationObserver. (http://localhost:7357/dwds/src/injected/client.js:1269:18)
Environment [✓] Flutter (Channel stable, 2.0.2, on macOS 11.0.1 20B50 darwin-x64, locale de-DE) • Flutter version 2.0.2 at /Users/christiankirst/development/flutter • Framework revision 8962f6dc68 (10 days ago), 2021-03-11 13:22:20 -0800 • Engine revision 5d8bf811b3 • Dart version 2.12.1
flutter_facebook_auth: 3.1.1